后台开发积累经验

1、邮箱正则表达式

^([a-zA-Z0-9]+[_|\\-|\\.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|\\-|\\.]?)*[a-zA-Z0-9]+\\.[a-zA-Z]{2,3}$

2、(HX)文件下载原理

根据传入的id,在数据库中找到对应的enyity类,将其转化为dto类,使用工具类DTOUtils.map("实体类对象",XXXXDto.class);

3、String的intern()方法,对于任意两个字符串 s 和 t,当且仅当 s.equals(t) 为 true 时,s.intern() == t.intern() 才为 true。该方法的返回值是一个字符串,内容与调用此方法的字符串相同,但一定取自具有唯一字符串的池。

4、get和post请求的区别

  1)哪些情况下,浏览器会发送get请求?

      (1)直接在浏览器地址栏输入某个地址

      (2)点击链接

      (3)表单默认提交的方式

  2)哪些情况下,浏览器会发送post请求?

       设置表单method='post'

  3)get请求的特点

    a.请求参数会添加请求资源路径的后面,只能添加少量参数(因为请求行只有一行,大约只能存放2k左右的数据)
    b.请求参数会显示在浏览器地址栏,路由器会记录请求地址
  4)post请求的特点
     a.请求参数添加到实体内容里面,可以添加大量的参数(也解释了为什么浏览器地址栏不能发送post请求,在地址栏我们只 能填写URL,并不能进入Http包的实体当中)
     b.相对安全,但是,post请求不会对请求参数进行加密处理(可以使用Https协议来保证数据安全)

5、密码加盐
在密码学中,是指通过在密码任意固定位置插入特定的字符串,让散列后的结果和使用源码的散列结果不相符,这种过程称之为“加盐”

6、重新抛出的异常必须保留原来的异常,即throw new NewException("message", e); 而不能写成throw new NewException("message")。

7、在所有异常被捕获且没有重新抛出的地方必须写日志。 

8、框架尽量捕获低级异常,并封装成高级异常重新抛出,隐藏低级异常的细节。

9、三种获取Class对象的方式:

       1)根据类名:类名.class

       2)根据对象:对象.getClass();

       3)根据全限定类名:Class.forName(“全限定类名”);

10、sql尽量精准化,比如少出现like,多用等于(视情况而定)

11、对字符串进行截取(substring,charAt)时,先对操作字符串进行对象的存在性(是否为空)及长度检查后,在进行操作。

12、mybatis中映射文件的sql中比较大小时要防止"<"被解析成标签,写法如下

 <![CDATA[ 
                  AND l.HANDLE_TIME < #{maxValue}
  ]]>

13、删除文件

 File sf = = new File(path);
 sf.delete();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值