AppFuse 3的乱码问题

在AppFuse 3.0.0版本下,执行特定命令后出现页面乱码问题。该文详细记录了问题排查过程及最终解决方案,即通过调整Hibernate插件配置来间接解决资源文件乱码的现象。
书接上回:AppFuse 3常见问题与解决方法 ,一个新问题:乱码! 在3.0.0版本下,执行mvn appfuse:full-source命令后使用mvn jetty:run启动工程,页面上就出现了乱码。我要说的是这个乱码问题非常有趣,它的有趣之处在于最后的解决方法看上去与问题差的太远。这个解决方法是:找到pom中对hibernate3-maven-plugin的配置,将其中的<executions/>部分注释掉,即不在process-test-resources阶段执行hbm2ddl。(如果你需要导出schema到数据库,可以手动执行mvn hibernate3:hbm2ddl,这也更符合实际开发的需要)。是的,看上去没有任何关系,但是问题就是出在了这里!下面我们回退到问题发生时一步步地进行排查。对于本文列出之外的一些细节问题,可以参考:基于Appfuse 2.1快速构建工程的注意事项 本文原文出处: http://blog.csdn.net/bluishglc/article/details/38640715 严禁任何形式的转载,否则将委托CSDN官方维护权益!

首先,查看编译之后的输出目录target/classes下的中文properties文件,可以确定这件文件本身就没有转码,是native2ascii插件没有正常工作吗?通过检查,发现问题不在native2ascii-maven-plugin的配置上。使用mvn clean package -X查看maven执行过程中的log信息,发现了下面一段有趣的输出:

[DEBUG] -----------------------------------------------------------------------
[DEBUG] Goal:          org.apache.maven.plugins:maven-resources-plugin:2.6:resources (default-resources)
[DEBUG] Style:         Regular
[DEBUG] Configuration: <?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <buildFilters default-value="${project.build.filters}"/>
  <encoding default-value="${project.build.sourceEncoding}">${encoding}</encoding>
  <escapeString>${maven.resources.escapeString}</escapeString>
  <escapeWindowsPaths default-value="true">${maven.resources.escapeWindowsPaths}</escapeWindowsPaths>
  <includeEmptyDirs default-value="false">${maven.resources.includeEmptyDirs}</includeEmptyDirs>
  <outputDirectory default-value="${project.build.outputDirectory}"/>
  <overwrite default-value="false">${maven.resources.overwrite}</overwrite>
  <project default-value="${project}"/>
  <resources default-value="${project.resources}"/>
  <session default-value="${session}"/>
  <supportMultiLineFiltering default-value="false">${maven.resources.supportMultiLineFiltering}</supportMultiLineFiltering>
  <useBuildFilters default-value="true"/>
  <useDefaultDelimiters default-value="true"/>
</configuration>
[DEBUG] -----------------------------------------------------------------------
[DEBUG] Goal:          org.apache.maven.plugins:maven-compiler-plugin:3.1:compile (default-compile)
[DEBUG] Style:         Regular
[DEBUG] Configuration: <?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <basedir default-value="${basedir}"/>
  <buildDirectory default-value="${project.build.directory}"/>
  <classpathElements default-value="${project.compileClasspathElements}"/>
  <compileSourceRoots default-value="${project.compileSourceRoots}"/>
  <compilerId default-value="javac">${maven.compiler.compilerId}</compilerId>
  <compilerReuseStrategy default-value="${reuseCreated}">${maven.compiler.compilerReuseStrategy}</compilerReuseStrategy>
  <compilerVersion>${maven.compiler.compilerVersion}</compilerVersion>
  <debug default-value="true">${maven.compiler.debug}</debug>
  <debuglevel>${maven.compiler.debuglevel}</debuglevel>
  <encoding default-value="${project.build.sourceEncoding}">${encoding}</encoding>
  <executable>${maven.compiler.executable}</executable>
  <failOnError default-value="true">${maven.compiler.failOnError}</failOnError>
  <forceJavacCompilerUse default-value="false">${maven.compiler.forceJavacCompilerUse}</forceJavacCompilerUse>
  <fork default-value="false">${maven.compiler.fork}</fork>
  <generatedSourcesDirectory default-value="${project.build.directory}/generated-sources/annotations"/>
  <maxmem>${maven.compiler.maxmem}</maxmem>
  <meminitial>${maven.compiler.meminitial}</meminitial>
  <mojoExecution>${mojoExecution}</mojoExecution>
  <optimize default-value="false">${maven.compiler.optimize}</optimize>
  <outputDirectory default-value="${project.build.outputDirectory}"/>
  <projectArtifact default-value="${project.artifact}"/>
  <showDeprecation default-value="false">${maven.compiler.showDeprecation}</showDeprecation>
  <showWarnings default-value="false">${maven.compiler.showWarnings}</showWarnings>
  <skipMain>${maven.main.skip}</skipMain>
  <skipMultiThreadWarning default-value="false">${maven.compiler.skipMultiThreadWarning}</skipMultiThreadWarning>
  <source default-value="1.5">1.7</source>
  <staleMillis default-value="0">${lastModGranularityMs}</staleMillis>
  <target default-value="1.5">1.7</target>
  <useIncrementalCompilation default-value="true">${maven.compiler.useIncrementalCompilation}</useIncrementalCompilation>
  <verbose default-value="false">${maven.compiler.verbose}</verbose>
  <mavenSession default-value="${session}"/>
  <session default-value="${session}"/>
</configuration>
[DEBUG] -----------------------------------------------------------------------
[DEBUG] Goal:          org.codehaus.mojo:native2ascii-maven-plugin:1.0-beta-1:native2ascii (native2ascii-utf8)
[DEBUG] Style:         Regular
[DEBUG] Configuration: <?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <encoding default-value="${project.build.sourceEncoding}">UTF8</encoding>
  <includes>
    <include>ApplicationResources_zh*.properties</include>
    <include>displaytag_zh*.properties</include>
  </includes>
  <tempDir default-value="${project.build.directory}"/>
  <workDir default-value="${project.build.outputDirectory}"/>
</configuration>
[DEBUG] -----------------------------------------------------------------------
[DEBUG] Goal:          org.apache.maven.plugins:maven-resources-plugin:2.6:testResources (default-testResources)
[DEBUG] Style:         Regular
[DEBUG] Configuration: <?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <buildFilters default-value="${project.build.filters}"/>
  <encoding default-value="${project.build.sourceEncoding}">${encoding}</encoding>
  <escapeString>${maven.resources.escapeString}</escapeString>
  <escapeWindowsPaths default-value="true">${maven.resources.escapeWindowsPaths}</escapeWindowsPaths>
  <includeEmptyDirs default-value="false">${maven.resources.includeEmptyDirs}</includeEmptyDirs>
  <outputDirectory default-value="${project.build.testOutputDirectory}"/>
  <overwrite default-value="false">${maven.resources.overwrite}</overwrite>
  <project default-value="${project}"/>
  <resources default-value="${project.testResources}"/>
  <session default-value="${session}"/>
  <skip>${maven.test.skip}</skip>
  <supportMultiLineFiltering default-value="false">${maven.resources.supportMultiLineFiltering}</supportMultiLineFiltering>
  <useBuildFilters default-value="true"/>
  <useDefaultDelimiters default-value="true"/>
</configuration>
[DEBUG] --- init fork of com.github:demo:1.0-SNAPSHOT for org.codehaus.mojo:hibernate3-maven-plugin:2.2:hbm2ddl (default) ---
[DEBUG] Dependencies (collect): []
[DEBUG] Dependencies (resolve): []
[DEBUG] -----------------------------------------------------------------------
[DEBUG] Goal:          org.apache.maven.plugins:maven-resources-plugin:2.6:resources (default-resources)
[DEBUG] Style:         Regular
[DEBUG] Configuration: <?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <buildFilters default-value="${project.build.filters}"/>
  <encoding default-value="${project.build.sourceEncoding}">${encoding}</encoding>
  <escapeString>${maven.resources.escapeString}</escapeString>
  <escapeWindowsPaths default-value="true">${maven.resources.escapeWindowsPaths}</escapeWindowsPaths>
  <includeEmptyDirs default-value="false">${maven.resources.includeEmptyDirs}</includeEmptyDirs>
  <outputDirectory default-value="${project.build.outputDirectory}"/>
  <overwrite default-value="false">${maven.resources.overwrite}</overwrite>
  <project default-value="${project}"/>
  <resources default-value="${project.resources}"/>
  <session default-value="${session}"/>
  <supportMultiLineFiltering default-value="false">${maven.resources.supportMultiLineFiltering}</supportMultiLineFiltering>
  <useBuildFilters default-value="true"/>
  <useDefaultDelimiters default-value="true"/>
</configuration>
[DEBUG] --- exit fork of com.github:demo:1.0-SNAPSHOT for org.codehaus.mojo:hibernate3-maven-plugin:2.2:hbm2ddl (default) ---

这段log的有趣之处在于:resources:resources 被执行了两次。第一次是在native2ascii:native2ascii之前,第二次是在 native2ascii:native2ascii 执行之后执行hbm2ddl时又被重新调用了一次。为了准确地了解resources:resources和native2ascii:native2ascii的执行顺序,我们从它们各自的文档上找到它们默认绑定的周期说明:


resources:resources -> process-resources

native2ascii:native2ascii -> process-classes


maven的默认生命周期如下:
   

<phases>

  <phase>validate</phase>

  <phase>initialize</phase>

  <phase>generate-sources</phase>

  <phase>process-sources</phase>

  <phase>generate-resources</phase>

  <phase>process-resources</phase>

  <phase>compile</phase>

  <phase>process-classes</phase>

  <phase>generate-test-sources</phase>

  <phase>process-test-sources</phase>

  <phase>generate-test-resources</phase>

  <phase>process-test-resources</phase>

  <phase>test-compile</phase>

  <phase>process-test-classes</phase>

  <phase>test</phase>

  <phase>prepare-package</phase>

  <phase>package</phase>

  <phase>pre-integration-test</phase>

  <phase>integration-test</phase>

  <phase>post-integration-test</phase>

  <phase>verify</phase>

  <phase>install</phase>

  <phase>deploy</phase>

</phases>

按照正常的逻辑, resources:resources会先于native2ascii:native2ascii将所有指定的resource文件进行filter处理之后放置于target目录下,之后native2ascii:native2ascii跟进,对指定的文件进行转码,这是非常合理的处理方式,而我们的问题就出现在了对resources:resources第二次不正常的调用,这导致了之前经过转码的文件又被未经转码的文件覆盖了!从日志上看,导致resources:resources第二次执行的原因应该是在进入process-test-resources阶段后执行hbm2ddl触发的,也就是说是hbm2ddl的某个动作主动调用了resources:resources,至于具体的细节,是bug还是与maven3的兼容问题,这里我们不再深究,但是解决方法已经变得很清晰上,就是前文提到的做法。

内容概要:本文介绍了悬臂梁的有限元分析方法,重点采用多重网格高斯-赛德尔迭代法求解有限元方程,并提供了完整的Matlab代码实现。文章系统阐述了有限元法的基本原理,包括单元划分、刚度矩阵组装、边界条件处理及数值求解流程,结合多重网格技术提升求解效率,有效解决了传统迭代方法在大规模问题中收敛慢的问题。通过具体算例验证了该方法的准确性与高效性,展示了从建模到结果可视化的完整过程。; 适合人群:具备有限元基础理论知识和Matlab编程能力的力学、土木、机械等工程领域研究生或科研人员;适用于从事结构分析、数值计算方法研究的相关技术人员。; 使用场景及目标:①掌握有限元法在悬臂梁问题中的建模与实现过程;②理解并应用多重网格法加速高斯-赛德尔迭代的数值求解技术;③通过Matlab代码实践提升对数值算法与悬臂梁的有限元分析,采用多重网格高斯-赛德尔方法求解(Matlab代码实现)工程仿真结合的能力;④为复杂结构的高效数值模拟提供方法参考和技术支持。; 阅读建议:建议读者结合有限元教材同步学习,重点关注刚度矩阵的形成与边界条件施加细节,动手运行并调试提供的Matlab代码,尝试改变网格密度或材料参数以观察对结果的影响,深入理解多重网格算法在提升计算效率方面的作用。
【源码免费下载链接】:https://renmaiwang.cn/s/eb8qv DLNA(Digital Living Network Alliance,数字生活网络联盟)是一种标准化技术体系,旨在实现多种电子设备间的无缝媒体内容共享,涵盖音乐、视频与图片等多种形式。该技术体系特别适用于家庭网络环境,在此场景下,各类型终端设备如智能手机、电视机、电脑等可通过统一网络连接,并支持相互播放或分享多媒体文件。Dlna音乐播放器作为一个应用程序,通过DLNA规范实现对支持DMR(Digital Media Renderer,数字媒体渲染器)设备的搜索与连接功能。作为DLNA架构中的核心组件之一,DMR负责接收和处理来自其他设备的多媒体内容,并提供流媒体播放服务。例如,在支持DMR的智能音响系统中,用户可通过Dlna音乐播放器实现音乐文件的实时流式传输。在DLNA框架体系内,另一个关键角色是数字媒体控制器(DMC,Digital Media Controller)。作为该体系中的具体实施者之一,Dlna音乐播放器具备以下功能:首先可搜索并连接至支持DMR设备;其次提供播放与暂停操作;同时支持音量调节功能;此外能实时更新播放进度条,并通过监听设备状态变化实现事件响应。在"MusicDlnaDemo"文件中,很可能包含了一个演示性代码示例,用于展示开发基本Dlna音乐播放器的技术要点。该示例可能涵盖了设备发现、媒体控制及交互操作等功能模块,对于理解和构建自定义DLNA多媒体应用具有重要参考价值。开发此类应用需要对UPnP(Unified Platform for Plug-and-Play, 通用即插即用)协议有基本掌握能力,并具备处理网络通信、数据解析以及多线程编程的经验,以确保程序的响应性和稳定性。Dlna音乐播放器作为一个强大的工具,通过其技术体系的应用,使得多媒体内容共享更加便
内容概要:本文介绍了基于自适应傅里叶分解(AFD)的多通道信号分析方法,并提供了完整的Matlab代码实现。AFD是一种先进的信号处理技术,能够有效处理非平稳、非线性信号,特别适用于多通道信号的高精度频域分析。文中详细阐述了AFD的基本原理、算法流程及其在实际工程中的应用价值,尤其强调其在机械故障诊断(如轴承故障检测)等领域的实用性。此外,文档还附带了多个相关案例,涵盖倒谱预白化、平方包络谱分析等技术,展示了信号处理与故障诊断相结合的具体实现路径。配套资源包括可运行的Matlab代码和网盘资料链接,便于读者复现与拓展研究。; 适合人群:具备一定信号处理基础和Matlab编程能力的研究生、科研人员及从事机械故障诊断、【自适应傅里叶分解AFD】多通道信号分析的自适应傅里叶分解(Matlab代码实现)电力电子、自动化等相关领域的工程技术人员。; 使用场景及目标:①用于复杂工况下多通道信号的频域分解与特征提取;②应用于旋转机械(如轴承)在变速条件下的故障诊断;③作为科研教学工具,帮助理解AFD算法机制并开展创新性研究; 阅读建议:建议结合提供的Matlab代码逐模块调试运行,配合理论部分深入理解算法细节,同时可参考文档中列举的其他信号处理与优化算法案例进行横向对比与综合应用。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Laurence 

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值