文档章节

2015年创业中遇到的技术问题:1-10(乱码-SpringMVC-jquery-JSON等)

FansUnion
 FansUnion
发布于 2015/10/22 10:29
字数 1441
阅读 5
收藏 0
点赞 0
评论 0
1.数据库表名重构。
   之前受PHP等程序的影响,数据库表名喜欢用数据库的名称作为前缀,比如“p2p_account”。
   在经过大量的实践之后,发现Java程序中,基本没有这个必要。
   so,从今天开始,数据库表明不再加上多余的前缀了。
   
   Java的Dao和Mybatis的xml,大量用到了数据库表名,我当然不笨,想到的是Eclipse的replace替换功能。
   把“p2p_”替换成“”就可以了。
   替换之前,随机抽样,选几个文件,看看是不是有“误杀”,尚未发现。
   
   mysql数据库的表名,也想导成sql文件,再同样直接替换的,后来发现不行,最近导入了IP库,有几十MB,还是手动重命名算了。
   
   类似的问题,之前手动把Mybatis中的“大写”转换成看起来更顺眼的“小写”,手动改的,后来多亏boss提醒,用的是Eclipse的快捷键,
   “Ctrl+shift+Y”。
   今后,要开动大脑,避免这种苦力活。
   
2.properties乱码问题。
   默认情况下,.properties文件是ISO-8859-1编码。输入中文,要么乱码,要么被Eclipse转换成对应的UTF-8字符,进而正常显示。
   现在有个问题,想在proerties加入中文注释,“#这是个路径”,其中"这个是路径"会被转成成“#aaaa”这种码。
   问题是,注释中的“#aaaa”在Eclipse下,不会自动翻译成“中文”,而没有注释的则可以。
   
   为了解决这个问题,想的是,把“.properties”手动设置UTF-8编码保存,但是,也不能直接用中文,
   中文的变量a=你好,不会正常解析。
   
   我们想这样:
   #a你好
   a=#aaaa#aaa
   
   这样有个不好的地方是,UTF-8编码,Eclipse不会自动把输入的中文,转换成“#aaaa”这种格式。
   还得手动,用JDK自带的工具转。
   
   总之呢,没有一种很好的方式,只能“维持现状”了。

   中文,永远都是个老大难的问题。谁让,最初设计软件标准的不是国人呢。
   
3.SpringMVC文件路径。
 p2p.backend_page=E:\GitRepository\backend-system
 <mvc:resources  mapping="/tpl/**" location="file:${p2p.backend_page}/tpl/"/>
 这个地方的文件路径,不正确,有问题。
 
 "p2p.backend_page=E:/GitRepository/backend-system",这种才是正确的。

4.SpringMVC获取request。
a. 在web.xml中配置一个监听
<listener>  
        <listener-class>  
            org.springframework.web.context.request.RequestContextListener  
        </listener-class>  
</listener>  
   b.之后在程序里可以用
HttpServletRequest request = ((ServletRequestAttributes)RequestContextHolder.getRequestAttributes()).getRequest();  

这种方法,是我需要的,方便在工具类中获得上下文中的request。
比如,记录操作日志,从request中获得ip和referer等相同的属性,可以写成1个通用的方法处理。


5.Mybatis的一个大坑啊。
有问题:mybatis会把最后一个if中的“,”给去掉,sql变成了“UPDATE p2p_user set paypwd=? uptime=now()”,进而导致sql语法错误。
<update id="update" parameterType="User">
UPDATE p2p_user 
<set>
<if test="umobile!=null">
umobile = #{umobile},
</if>
<if test="paypwd != null">
paypwd = #{paypwd},
</if>
</set>
uptime = now()
WHERE uid = #{uid}
</update>

没问题:如果一定修改uptime字段,就用test="true",避免上面的问题。
<update id="update" parameterType="User">
UPDATE p2p_user 
<set>
<if test="umobile!=null">
umobile = #{umobile},
</if>
<if test="paypwd != null">
paypwd = #{paypwd},
</if>
<if test="true">uptime = now()</if>
</set>
WHERE uid = #{uid}
</update>
6.SpringMVC的URL匹配问题,是否带斜杠/。
@RequestMapping("/loan")
public class LoanInfoController extends BaseController {
   @RequestMapping("")
public String index(HttpServletRequest request){
return "loan/index";
}
//用@RequestMapping("")可以匹配到"/loan"和"/loan/"。
}


public class LoanInfoController extends BaseController {
   @RequestMapping("/loan")
public String index(HttpServletRequest request){
return "loan/index";
}
//用@RequestMapping("")可以匹配到"/loan"和"/loan/"。(分析是这样,没有尝试)
}

public class LoanInfoController extends BaseController {
   @RequestMapping("/loan/")
public String index(HttpServletRequest request){
return "loan/index";
}
//用@RequestMapping("")只可以匹配到"/loan/"。
}
比较有疑问的是,“/loan”能直接匹配到,还是经过SpringMVC处理了,然后再匹配到的。

7.HttpServletRequest获得端口号。
 getLocalPort 可以获得8080
 getRemotePort 获得的是61132之类的服务器端的端口号,不是想要的。
 
 可以参考这篇文章的总结: http://blog.csdn.net/ranmudaofa/article/details/39785785
 
8.jquery获得修改iframe的src,父页面和当前页面的问题。
a.html
<iframe src="${base}/welcome.html" id="mainFrame" frameborder="0"
width="80%" height="500"></iframe>
在a.html中有个iframe,点击a中的某个按钮,更新iframe的src属性。
加载welcome.html页面之后,手动修改iframe的src,但是页面没有刷新。

后来,通过chrome的debug发现了问题。
var mainFrame=$("#mainFrame");子页面中获得的mainFrame没有src属性。

最终确定,a.html和b.html虽然都找到了mainFrame,但是不是同一个元素,这是为啥呢?

解决办法:
父页面:mainFrame=$("#mainFrame"); 
子页面:mainFrame=$("#mainFrame",window.parent.document); //等价于window.parent.document.getElementById("mainFrame");

如果写通用的方法,需要判断src是否有值。

9.JS的函数名是关键字。
  function delete(acl,ename);
  “delete”是js中的关键字,不能作为函数名称。
  这也说明,把java的模版文件用“.html”后缀比较方便,Eclipse可以给出提示。
  
  妈蛋,自己写的组件里,给超链接绑定一个事件,“remove”方法竟然也貌似冲突了,因为我随便用了个“a”方法,是可以响应的。

10.奇葩的JSON参数接收问题。
原来用form表单提交,有个属性名字叫做“amoun.yuan”,让后端
Money amount对象的字段yuan接收正常。

现在用JSON请求,参数名“amount.yuan”,接收失败。
"amount.yuan" : amount。

怎么说呢,如果只是接收不到参数,我表示非常理解。
但报的错误确是400,bad request。

我一直以为是,@RequestParam,某个参数没有提交过来导致的。

现在终于搞明白了,今后坚决不再用“a.b”这种形式发送json的参数了。

版权声明:本文为博主原创文章,未经博主允许不得转载。

© 著作权归作者所有

共有 人打赏支持
FansUnion
粉丝 56
博文 857
码字总数 825464
作品 0
丰台
高级程序员

暂无相关文章

如何优雅的编程——C语言界面的一点小建议

我们鼓励在编程时应有清晰的哲学思维,而不是给予硬性规则。我并不希望你们能认可所有的东西,因为它们只是观点,观点会随着时间的变化而变化。可是,如果不是直到现在把它们写在纸上,长久以...

柳猫 ⋅ 16分钟前 ⋅ 0

从零手写 IOC容器

概述 IOC (Inversion of Control) 控制反转。熟悉Spring的应该都知道。那么具体是怎么实现的呢?下面我们通过一个例子说明。 1. Component注解定义 package cn.com.qunar.annotation;impo...

轨迹_ ⋅ 16分钟前 ⋅ 0

系统健康检查利器-Spring Boot-Actuator

前言 实例由于出现故障、部署或自动缩放的情况,会进行持续启动、重新启动或停止操作。它可能导致它们暂时或永久不可用。为避免问题,您的负载均衡器应该从路由中跳过不健康的实例,因为它们...

harries ⋅ 18分钟前 ⋅ 0

手把手教你搭建vue-cli脚手架-详细步骤图文解析[vue入门]

写在前面: 使用 vue-cli 可以快速创建 vue 项目,vue-cli很好用,但是在最初搭建环境安装vue-cli及相关内容的时候,对一些人来说是很头疼的一件事情,本人在搭建vue-cli的项目环境的时候也是...

韦姣敏 ⋅ 28分钟前 ⋅ 0

12c rman中输入sql命令

12c之前版本,要在rman中执行sql语句,必须使用sql "alter system switch logfile"; 而在12c版本中,可以支持大量的sql语句了: 比如: C:\Users\zhengquan>rman target / 恢复管理器: Release 1...

tututu_jiang ⋅ 42分钟前 ⋅ 0

Nginx的https配置记录以及http强制跳转到https的方法梳理

Nginx的https配置记录以及http强制跳转到https的方法梳理 一、Nginx安装(略) 安装的时候需要注意加上 --with-httpsslmodule,因为httpsslmodule不属于Nginx的基本模块。 Nginx安装方法: ...

Yomut ⋅ 58分钟前 ⋅ 0

SpringCloud Feign 传递复杂参数对象需要注意的地方

1.传递复杂参数对象需要用Post,另外需要注意,Feign不支持使用GetMapping 和PostMapping @RequestMapping(value="user/save",method=RequestMethod.POST) 2.在传递的过程中,复杂对象使用...

@林文龙 ⋅ 今天 ⋅ 0

如何显示 word 左侧目录大纲

打开word说明文档,如下图,我们发现左侧根本就没有目录,给我们带来很大的阅读障碍 2 在word文档的头部菜单栏中,切换到”视图“选项卡 3 然后勾选“导航窗格”选项 4 我们会惊奇的发现左侧...

二营长意大利炮 ⋅ 今天 ⋅ 0

智能合约编程语言Solidity之线上开发工具

工具地址:https://ethereum.github.io/browser-solidity/ 实例实验: 1.创建hello.sol文件 2.调试输出结果

硅谷课堂 ⋅ 今天 ⋅ 0

ffmpeg 视频格式转换

转 Mp4 格式 #> ffmpeg -i input.avi -c:v libx264 output.mp4#> ffmpeg -i input.avi -c:v libx264 -strict -2 output.mp4#> ffmpeg -i input.avi -c:v libx264 -strict -2 -s 1......

Contac ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部