Struts2中struts-default.xml、struts.xml 及struts.properties詳解
1) struts-default.xml
該檔案位于struts2-core-2.1.8.1.jar包内,是struts2架構預設加載的配置檔案。它定義struts2一些核心的bean和攔截器。
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<!--struts2中工廠bean的定義-->
<bean class="com.opensymphony.xwork2.ObjectFactory" name="xwork" />
<bean type="com.opensymphony.xwork2.ObjectFactory" name="struts" class="org.apache.struts2.impl.StrutsObjectFactory" />
<bean type="com.opensymphony.xwork2.ActionProxyFactory" name="xwork" class="com.opensymphony.xwork2.DefaultActionProxyFactory"/>
<bean type="com.opensymphony.xwork2.ActionProxyFactory" name="struts" class="org.apache.struts2.impl.StrutsActionProxyFactory"/>
<!--類型檢測bean的定義-->
<bean type="com.opensymphony.xwork2.util.ObjectTypeDeterminer" name="tiger" class="com.opensymphony.xwork2.util.GenericsObjectTypeDeterminer"/>
<bean type="com.opensymphony.xwork2.util.ObjectTypeDeterminer" name="notiger" class="com.opensymphony.xwork2.util.DefaultObjectTypeDeterminer"/>
<bean type="com.opensymphony.xwork2.util.ObjectTypeDeterminer" name="struts" class="com.opensymphony.xwork2.util.DefaultObjectTypeDeterminer"/>
<!--檔案上傳bean的定義-->
<bean type="org.apache.struts2.dispatcher.mapper.ActionMapper" name="struts" class="org.apache.struts2.dispatcher.mapper.DefaultActionMapper" />
<bean type="org.apache.struts2.dispatcher.mapper.ActionMapper" name="composite" class="org.apache.struts2.dispatcher.mapper.CompositeActionMapper" />
<bean type="org.apache.struts2.dispatcher.mapper.ActionMapper" name="restful" class="org.apache.struts2.dispatcher.mapper.RestfulActionMapper" />
<bean type="org.apache.struts2.dispatcher.mapper.ActionMapper" name="restful2" class="org.apache.struts2.dispatcher.mapper.Restful2ActionMapper" />
<bean type="org.apache.struts2.dispatcher.multipart.MultiPartRequest" name="struts" class="org.apache.struts2.dispatcher.multipart.JakartaMultiPartRequest" scope="default" optional="true"/>
<bean type="org.apache.struts2.dispatcher.multipart.MultiPartRequest" name="jakarta" class="org.apache.struts2.dispatcher.multipart.JakartaMultiPartRequest" scope="default" optional="true" />
<!--标簽庫bean的定義-->
<bean type="org.apache.struts2.views.TagLibrary" name="s" class="org.apache.struts2.views.DefaultTagLibrary" />
<!--一些常用視圖bean的定義-->
<bean class="org.apache.struts2.views.freemarker.FreemarkerManager" name="struts" optional="true"/>
<bean class="org.apache.struts2.views.velocity.VelocityManager" name="struts" optional="true" />
<bean class="org.apache.struts2.components.template.TemplateEngineManager" />
<bean type="org.apache.struts2.components.template.TemplateEngine" name="ftl" class="org.apache.struts2.components.template.FreemarkerTemplateEngine" />
<bean type="org.apache.struts2.components.template.TemplateEngine" name="vm" class="org.apache.struts2.components.template.VelocityTemplateEngine" />
<bean type="org.apache.struts2.components.template.TemplateEngine" name="jsp" class="org.apache.struts2.components.template.JspTemplateEngine" />
<!--類型轉換bean的定義-->
<bean type="com.opensymphony.xwork2.util.XWorkConverter" name="xwork1" class="com.opensymphony.xwork2.util.XWorkConverter" />
<bean type="com.opensymphony.xwork2.util.XWorkConverter" name="struts" class="com.opensymphony.xwork2.util.AnnotationXWorkConverter" />
<bean type="com.opensymphony.xwork2.TextProvider" name="xwork1" class="com.opensymphony.xwork2.TextProviderSupport" />
<bean type="com.opensymphony.xwork2.TextProvider" name="struts" class="com.opensymphony.xwork2.TextProviderSupport" />
<!-- Struts2中一些可以靜态注入的bean,也就是不需要執行個體化的 -->
<bean class="com.opensymphony.xwork2.ObjectFactory" static="true" />
<bean class="com.opensymphony.xwork2.util.XWorkConverter" static="true" />
<bean class="com.opensymphony.xwork2.util.OgnlValueStack" static="true" />
<bean class="org.apache.struts2.dispatcher.Dispatcher" static="true" />
<bean class="org.apache.struts2.components.Include" static="true" />
<bean class="org.apache.struts2.dispatcher.FilterDispatcher" static="true" />
<bean class="org.apache.struts2.views.util.ContextUtil" static="true" />
<bean class="org.apache.struts2.views.util.UrlHelper" static="true" />
<!-- 定義Struts2預設包-->
<package name="struts-default" abstract="true">
<!-- 結果類型的種類-->
<result-types>
<result-type name="chain" class="com.opensymphony.xwork2.ActionChainResult"/>
<result-type name="dispatcher" class="org.apache.struts2.dispatcher.ServletDispatcherResult" default="true"/>
<result-type name="freemarker" class="org.apache.struts2.views.freemarker.FreemarkerResult"/>
<result-type name="httpheader" class="org.apache.struts2.dispatcher.HttpHeaderResult"/>
<result-type name="redirect" class="org.apache.struts2.dispatcher.ServletRedirectResult"/>
<result-type name="redirectAction" class="org.apache.struts2.dispatcher.ServletActionRedirectResult"/>
<result-type name="stream" class="org.apache.struts2.dispatcher.StreamResult"/>
<result-type name="velocity" class="org.apache.struts2.dispatcher.VelocityResult"/>
<result-type name="xslt" class="org.apache.struts2.views.xslt.XSLTResult"/>
<result-type name="plainText" class="org.apache.struts2.dispatcher.PlainTextResult" />
<result-type name="redirect-action" class="org.apache.struts2.dispatcher.ServletActionRedirectResult"/>
<result-type name="plaintext" class="org.apache.struts2.dispatcher.PlainTextResult" />
</result-types>
<!--struts2中攔截器的定義-->
<interceptors>
<!--實作在不同請求中相似參數别名的準換-->
<interceptor name="alias" class="com.opensymphony.xwork2.interceptor.AliasInterceptor"/>
<!--與Spring整合時自動裝配的攔截器-->
<interceptor name="autowiring" class="com.opensymphony.xwork2.spring.interceptor.ActionAutowiringInterceptor"/>
<!--建構一個action鍊,使目前action可以通路前一個action,與<result-type="chain" />配合使用-->
<interceptor name="chain" class="com.opensymphony.xwork2.interceptor.ChainingInterceptor"/>
<!--負責類型轉換的攔截器-->
<interceptor name="conversionError" class="org.apache.struts2.interceptor.StrutsConversionErrorInterceptor"/>
<!--使用配置的name,value來是指cookies -->
<interceptor name="cookie" class="org.apache.struts2.interceptor.CookieInterceptor"/>
<!--負責建立httpSession-->
<interceptor name="createSession" class="org.apache.struts2.interceptor.CreateSessionInterceptor" />
<!--輸出調試資訊-->
<interceptor name="debugging" class="org.apache.struts2.interceptor.debugging.DebuggingInterceptor" />
<!--擴充引用-->
<interceptor name="externalRef" class="com.opensymphony.xwork2.interceptor.ExternalReferencesInterceptor"/>
<!--背景執行action負責發送等待畫面給使用者-->
<interceptor name="execAndWait" class="org.apache.struts2.interceptor.ExecuteAndWaitInterceptor"/>
<!--異常處理-->
<interceptor name="exception" class="com.opensymphony.xwork2.interceptor.ExceptionMappingInterceptor"/>
<!--檔案上傳,解析表單域的内容-->
<interceptor name="fileUpload" class="org.apache.struts2.interceptor.FileUploadInterceptor"/>
<!--支援國際化-->
<interceptor name="i18n" class="com.opensymphony.xwork2.interceptor.I18nInterceptor"/>
<!--日志記錄-->
<interceptor name="logger" class="com.opensymphony.xwork2.interceptor.LoggingInterceptor"/>
<!--模型攔截器,當action實作了ModelDriven接口時,負責把getModel的結果放入valueStack中-->
<interceptor name="modelDriven" class="com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor"/>
<!--有生命周期的ModelDriven-->
<interceptor name="scopedModelDriven" class="com.opensymphony.xwork2.interceptor.ScopedModelDrivenInterceptor"/>
<!--負責解析請求中的參數,并指派給action中對應的屬性-->
<interceptor name="params" class="com.opensymphony.xwork2.interceptor.ParametersInterceptor"/>
<!--實作該Preparable接口的action,會調用攔截器的prepare方法-->
<interceptor name="prepare" class="com.opensymphony.xwork2.interceptor.PrepareInterceptor"/>
<!--負責将action 标簽下的param參數值傳遞給action執行個體-->
<interceptor name="staticParams" class="com.opensymphony.xwork2.interceptor.StaticParametersInterceptor"/>
<!--範圍轉換-->
<interceptor name="scope" class="org.apache.struts2.interceptor.ScopeInterceptor"/>
<!--用于通路Servlet API-->
<interceptor name="servletConfig" class="org.apache.struts2.interceptor.ServletConfigInterceptor"/>
<interceptor name="sessionAutowiring" class="org.apache.struts2.spring.interceptor.SessionContextAutowiringInterceptor"/>
<!--輸出action執行時間-->
<interceptor name="timer" class="com.opensymphony.xwork2.interceptor.TimerInterceptor"/>
<!--防止表單重複送出-->
<interceptor name="token" class="org.apache.struts2.interceptor.TokenInterceptor"/>
<!--與token攔截器相似,隻是把token儲存到HttpSession-->
<interceptor name="tokenSession" class="org.apache.struts2.interceptor.TokenSessionStoreInterceptor"/>
<!--負責表單字段的驗證 *-validation.xml-->
<interceptor name="validation" class="org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor"/>
<!--負責執行action的validate()-->
<interceptor name="workflow" class="com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor"/>
<!--存儲和重新擷取Action 消息/錯誤/字段錯誤為Action,實作ValidationAware接口到seesion-->
<interceptor name="store" class="org.apache.struts2.interceptor.MessageStoreInterceptor" />
<!--添加自動checkbox處理代碼,這樣檢探測checkbox和添加它作為一個參數使用預設值(通常’false’).使用一個指定名字隐藏字段探測沒送出的checkbox-->
<interceptor name="checkbox" class="org.apache.struts2.interceptor.CheckboxInterceptor" />
<interceptor name="profiling" class="org.apache.struts2.interceptor.ProfilingActivationInterceptor" />
<!--JAAS服務攔截器-->
<interceptor name="roles" class="org.apache.struts2.interceptor.RolesInterceptor" />
<!-- 一個基本的攔截器棧 -->
<interceptor-stack name="basicStack">
<interceptor-ref name="exception"/>
<interceptor-ref name="servletConfig"/>
<interceptor-ref name="prepare"/>
<interceptor-ref name="checkbox"/>
<interceptor-ref name="params"/>
<interceptor-ref name="conversionError"/>
</interceptor-stack>
<!-- 簡單的validtion和webflow棧 -->
<interceptor-stack name="validationWorkflowStack">
<interceptor-ref name="basicStack"/>
<interceptor-ref name="validation"/>
<interceptor-ref name="workflow"/>
</interceptor-stack>
<!-- 檔案上傳的攔截器棧 -->
<interceptor-stack name="fileUploadStack">
<interceptor-ref name="fileUpload"/>
<interceptor-ref name="basicStack"/>
</interceptor-stack>
<!-- model-driven 棧 -->
<interceptor-stack name="modelDrivenStack">
<interceptor-ref name="modelDriven"/>
<interceptor-ref name="basicStack"/>
</interceptor-stack>
<!-- action鍊的攔截器棧 -->
<interceptor-stack name="chainStack">
<interceptor-ref name="chain"/>
<interceptor-ref name="basicStack"/>
</interceptor-stack>
<!-- i18n 攔截器棧 -->
<interceptor-stack name="i18nStack">
<interceptor-ref name="i18n"/>
<interceptor-ref name="basicStack"/>
</interceptor-stack>
<!-- 結合preparable和ModenDriven攔截器-->
<interceptor-stack name="paramsPrepareParamsStack">
<interceptor-ref name="exception"/>
<interceptor-ref name="alias"/>
<interceptor-ref name="params"/>
<interceptor-ref name="servletConfig"/>
<interceptor-ref name="prepare"/>
<interceptor-ref name="i18n"/>
<interceptor-ref name="chain"/>
<interceptor-ref name="modelDriven"/>
<interceptor-ref name="fileUpload"/>
<interceptor-ref name="checkbox"/>
<interceptor-ref name="staticParams"/>
<interceptor-ref name="params"/>
<interceptor-ref name="conversionError"/>
<interceptor-ref name="validation">
<param name="excludeMethods">input,back,cancel</param>
</interceptor-ref>
<interceptor-ref name="workflow">
<param name="excludeMethods">input,back,cancel</param>
</interceptor-ref>
</interceptor-stack>
<!--定義預設的攔截器棧 -->
<interceptor-stack name="defaultStack">
<interceptor-ref name="exception"/>
<interceptor-ref name="alias"/>
<interceptor-ref name="servletConfig"/>
<interceptor-ref name="prepare"/>
<interceptor-ref name="i18n"/>
<interceptor-ref name="chain"/>
<interceptor-ref name="debugging"/>
<interceptor-ref name="profiling"/>
<interceptor-ref name="scopedModelDriven"/>
<interceptor-ref name="modelDriven"/>
<interceptor-ref name="fileUpload"/>
<interceptor-ref name="checkbox"/>
<interceptor-ref name="staticParams"/>
<interceptor-ref name="params">
<param name="excludeParams">dojo/..*</param>
</interceptor-ref>
<interceptor-ref name="conversionError"/>
<interceptor-ref name="validation">
<param name="excludeMethods">input,back,cancel,browse</param>
</interceptor-ref>
<interceptor-ref name="workflow">
<param name="excludeMethods">input,back,cancel,browse</param>
</interceptor-ref>
</interceptor-stack>
<interceptor-stack name="completeStack">
<interceptor-ref name="defaultStack"/>
</interceptor-stack>
<interceptor-stack name="executeAndWaitStack">
<interceptor-ref name="execAndWait">
<param name="excludeMethods">input,back,cancel</param>
</interceptor-ref>
<interceptor-ref name="defaultStack"/>
<interceptor-ref name="execAndWait">
<param name="excludeMethods">input,back,cancel</param>
</interceptor-ref>
</interceptor-stack>
<interceptor name="external-ref" class="com.opensymphony.xwork2.interceptor.ExternalReferencesInterceptor"/>
<interceptor name="model-driven" class="com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor"/>
<interceptor name="static-params" class="com.opensymphony.xwork2.interceptor.StaticParametersInterceptor"/>
<interceptor name="scoped-model-driven" class="com.opensymphony.xwork2.interceptor.ScopedModelDrivenInterceptor"/>
<interceptor name="servlet-config" class="org.apache.struts2.interceptor.ServletConfigInterceptor"/>
<interceptor name="token-session" class="org.apache.struts2.interceptor.TokenSessionStoreInterceptor"/>
</interceptors>
<!--定義預設攔截器為"defaultStack"-->
<default-interceptor-ref name="defaultStack"/>
</package>
</struts>
2) struts.xml
該檔案是Struts2的核心配置檔案,位于web工程中,由架構自動加載,可以定義一些自己的action,interceptor,package等,該檔案的package 通常繼承struts-default包。子子產品的配置檔案以struts-XXX.xml命名。
下面是這個檔案的格式:
<?xml version="1.0" encoding="GBK"?>
<!-- 下面指定Struts 2配置檔案的DTD資訊 -->
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<!-- struts是Struts 2配置檔案的根元素 -->
<struts>
<!-- 下面元素可以出現0次,也可以無限多次 -->
<constant name="" value="" />
<!-- 下面元素可以出現0次,也可以無限多次 -->
<bean type="" name="" class="" scope="" static="" optional="" />
<!-- 下面元素可以出現0次,也可以無限多次 -->
<include file="" />
<!-- package元素是Struts配置檔案的核心,該元素可以出現0次,或者無限多次 -->
<package name="必填的包名" extends="" namespace="" abstract=""
externalReferenceResolver>
<!-- 該元素可以出現,也可以不出現,最多出現一次 -->
<result-types>
<!-- 該元素必須出現,可以出現無限多次-->
<result-type name="" class="" default="true|false">
<!-- 下面元素可以出現0次,也可以無限多次 -->
<param name="參數名">參數值</param>*
</result-type>
</result-types>
<!-- 該元素可以出現,也可以不出現,最多出現一次 -->
<interceptors>
<!-- 該元素的interceptor元素和interceptor-stack至少出現其中之一,
也可以二者都出現 -->
<!-- 下面元素可以出現0次,也可以無限多次 -->
<interceptor name="" class="">
<!-- 下面元素可以出現0次,也可以無限多次 -->
<param name="參數名">參數值</param>*
</interceptor>
<!-- 下面元素可以出現0次,也可以無限多次 -->
<interceptor-stack name="">
<!-- 該元素必須出現,可以出現無限多次-->
<interceptor-ref name="">
<!-- 下面元素可以出現0次,也可以無限多次 -->
<param name="參數名">參數值</param>*
</interceptor-ref>
</interceptor-stack>
</interceptors>
<!-- 下面元素可以出現0次,也可以無限多次 -->
<default-interceptor-ref name="">
<!-- 下面元素可以出現0次,也可以無限多次 -->
<param name="參數名">參數值</param>
</default-interceptor-ref>
<!-- 下面元素可以出現0次,也可以無限多次 -->
<default-action-ref name="">
<!-- 下面元素可以出現0次,也可以無限多次 -->
<param name="參數名">參數值</param>*
</default-action-ref>?
<!-- 下面元素可以出現0次,也可以無限多次 -->
<global-results>
<!-- 該元素必須出現,可以出現無限多次-->
<result name="" type="">
<!-- 該字元串内容可以出現0次或多次 -->
映射資源
<!-- 下面元素可以出現0次,也可以無限多次 -->
<param name="參數名">參數值</param>*
</result>
</global-results>
<!-- 下面元素可以出現0次,也可以無限多次 -->
<global-exception-mappings>
<!-- 該元素必須出現,可以出現無限多次-->
<exception-mapping name="" exception="" result="">
異常處理資源
<!-- 下面元素可以出現0次,也可以無限多次 -->
<param name="參數名">參數值</param>*
</exception-mapping>
</global-exception-mappings>
<action name="" class="" method="" converter="">
<!-- 下面元素可以出現0次,也可以無限多次 -->
<param name="參數名">參數值</param>*
<!-- 下面元素可以出現0次,也可以無限多次 -->
<result name="" type="">
映射資源
<!-- 下面元素可以出現0次,也可以無限多次 -->
<param name="參數名">參數值</param>*
</result>
<!-- 下面元素可以出現0次,也可以無限多次 -->
<interceptor-ref name="">
<!-- 下面元素可以出現0次,也可以無限多次 -->
<param name="參數名">參數值</param>*
</interceptor-ref>
<!-- 下面元素可以出現0次,也可以無限多次 -->
<exception-mapping name="" exception="" result="">
異常處理資源
<!-- 下面元素可以出現0次,也可以無限多次 -->
<param name="參數名">參數值</param>*
</exception-mapping>
</action>
</package>*
<struts>
3) struts.properties檔案
該檔案是struts2架構的全局屬性檔案,也是自動加載的檔案。該檔案包含了系列的key-value對。
該檔案完全可以配置在struts.xml檔案中,使用constant元素。下面是這個檔案中一些常見的配置項及說明。
### 指定加載struts2配置檔案管理器,預設為org.apache.struts2.config.DefaultConfiguration
### 開發者可以自定義配置檔案管理器,該類要實作Configuration接口,可以自動加載struts2配置檔案。
# struts.configuration=org.apache.struts2.config.DefaultConfiguration
### 設定預設的locale和字元編碼
# struts.locale=en_US
struts.i18n.encoding=UTF-8
### 指定struts的工廠類
# struts.objectFactory = spring
### 指定spring架構的裝配模式
### 裝配方式有: name, type, auto, and constructor (name 是預設裝配模式)
struts.objectFactory.spring.autoWire = name
### 該屬性指定整合spring時,是否對bean進行緩存,值為true or false,預設為true.
struts.objectFactory.spring.useClassCache = true
### 指定類型檢查
#struts.objectTypeDeterminer = tiger
#struts.objectTypeDeterminer = notiger
### 該屬性指定處理 MIME-type multipart/form-data,檔案上傳
# struts.multipart.parser=cos
# struts.multipart.parser=pell
struts.multipart.parser=jakarta
# 指定上傳檔案時的臨時目錄,預設使用 javax.servlet.context.tempdir
struts.multipart.saveDir=
struts.multipart.maxSize=2097152
### 加載自定義屬性檔案 (不要改寫struts.properties!)
# struts.custom.properties=application,org/apache/struts2/extension/custom
### 指定請求url與action映射器,預設為org.apache.struts2.dispatcher.mapper.DefaultActionMapper
#struts.mapper.class=org.apache.struts2.dispatcher.mapper.DefaultActionMapper
### 指定action的字尾,預設為action
struts.action.extension=action
### 被 FilterDispatcher使用
### 如果為 true 則通過jar檔案提供靜态内容服務.
### 如果為 false 則靜态内容必須位于 <context_path>/struts
struts.serve.static=true
### 被 FilterDispatcher使用
### 指定浏覽器是否緩存靜态内容,測試階段設定為false,釋出階段設定為true.
struts.serve.static.browserCache=true
### 設定是否支援動态方法調用,true為支援,false不支援.
struts.enable.DynamicMethodInvocation = true
### 設定是否可以在action中使用斜線,預設為false不可以,想使用需設定為true.
struts.enable.SlashesInActionNames = false
### 是否允許使用表達式文法,預設為true.
struts.tag.altSyntax=true
### 設定當struts.xml檔案改動時,是否重新加載.
### - struts.configuration.xml.reload = true
### 設定struts是否為開發模式,預設為false,測試階段一般設為true.
struts.devMode = false
### 設定是否每次請求,都重新加載資源檔案,預設值為false.
struts.i18n.reload=false
###标準的UI主題
### 預設的UI主題為xhtml,可以為simple,xhtml或ajax
struts.ui.theme=xhtml
###模闆目錄
struts.ui.templateDir=template
#設定模闆類型. 可以為 ftl, vm, or jsp
struts.ui.templateSuffix=ftl
###定位velocity.properties 檔案. 預設 velocity.properties
struts.velocity.configfile = velocity.properties
### 設定velocity的context.
struts.velocity.contexts =
### 定位toolbox.
struts.velocity.toolboxlocation=
### 指定web應用的端口.
struts.url.http.port = 80
### 指定加密端口
struts.url.https.port = 443
### 設定生成url時,是否包含參數.值可以為: none, get or all
struts.url.includeParams = get
### 設定要加載的國際化資源檔案,以逗号分隔.
# struts.custom.i18n.resources=testmessages,testmessages2
### 對于一些web應用伺服器不能處理HttpServletRequest.getParameterMap()
### 像 WebLogic, Orion, and OC4J等,須設定成true,預設為false.
struts.dispatcher.parametersWorkaround = false
### 指定freemarker管理器
#struts.freemarker.manager.classname=org.apache.struts2.views.freemarker.FreemarkerManager
### 設定是否對freemarker的模闆設定緩存
### 效果相當于把template拷貝到 WEB_APP/templates.
struts.freemarker.templatesCache=false
### 通常不需要修改此屬性.
struts.freemarker.wrapper.altMap=true
### 指定xslt result是否使用樣式表緩存.開發階段設為true,釋出階段設為false.
struts.xslt.nocache=false
### 設定struts自動加載的檔案清單.
struts.configuration.files=struts-default.xml,struts-plugin.xml,struts.xml
### 設定是否一直在最後一個slash之前的任何位置標明namespace.
struts.mapper.alwaysSelectFullNamespace=false