《JavaWeb第六章》

文件上传

1.文件上传的应用场景:提交作业    上传头像       提交简历(上传附件)    上传商品,图书图片

 

2.文件上传的前台如何编写以及注意事项:
(1)肯定需要用到表单
(2)文件上传的那一栏需要提供   input的type=file的组件,同样需要加name给后台获取
(3)回顾form表单的三大属性:
             A.action:表单的提交路径
             B.method:表单的提交方式,2大默认值,一般都是post,很少使用get
get/post的区别:get不安全会把数据暴露在URL地址上,可以携带的数据非常少只有几KB,速度较快
post安全不会把数据暴露在URL地址上,可以携带的数据非常多,速度较慢

             C.enctype:表单的类型  三大默认值:
                     a.普通表单:application/x-www-form-urlencoded  默认就是
                     b.功能表单:multipart/form-data 普通表单的升级版,可以用来实现文件上传
                     c.功能表单:text/plain  普通表单的升级版,可以用来实现大文本表单提交

(4)form表单属性需要注意的是:1.method必须为post   2.enctype必须为multipart/form-data

 

3.文件上传的后台如何编写以及注意事项:
(1)肯定需要用到Servlet  (Servlet怎么写依然怎么写)
(2)在类名的上面在加一个额外的注解:@MultipartConfig 表示该Servlet支持处理文件上传
(3)需要接受文件  通过req.getPart("前台的文件的name值");
         普通数据通过req.getParameter("前台的组件的name值")
         文件类型数据通过req.getPart("xxx");
(4)获取文件的相关信息
         通过第三步的Part part = req.getPart("xxx");
         来获取相关信息
         System.out.println(part.getContentType());//获取文件的类型
         System.out.println(part.getSize());//获取文件的大小 单位是字节
         System.out.println(part.getSubmittedFileName());//获取文件名

(5)保存用户上传的文件
         开始将用户上传的文件保存在本地服务器(本地的一个路径)
         声明一个文件的保存路径
         组装一下  需要将路径和文件名进行拼接
         String path = "D:\\uploadTest\\" + part.getSubmittedFileName();
         将part对象保存到path路径中 part.write(path);

数据校验

数据校验的三层防线:
1.前台的JS校验
2.后台的Java校验
3.数据库的约束校验    ---   主键约束    外键约束  唯一约束  自增约束   非空约束   检查约束   默认约束

 

JS数据校验的事件处理:
1.onsubmit  提交表单的时候进行统一的校验

2.onblur和onfouce  对表单内部的每个组件都进行一一校验

3.onchange  常用于下拉框和file组件   值发生了改变才触发

上述3个同时组合使用

 

校验分成三大类:
1.文本类型校验 例如文本框密码框等
2.单选框复选框校验 判断是否勾选的几个
3.文件类型校验 判断文件大小,文件类型,文件后缀名

Jquery对象不允许使用JS的相关方法,反正亦然

jquery对象和JS对象如何进行转换。

let a1 = document.getElementById("file");//dom/js对象
let a2 = $("#abc");//jquery对象

js转成jquery对象
$(a1)表示将a1对象转成了jquery对象

jquery对象转成js对象
a2[0];表示OK了


let a1 = document.getElementById("abc");
let a2 = $("#abc");
console.log(a1.innerText);   //按钮123
console.log(a2.innerText);   //报错
console.log(  a1.text()  );  //报错
console.log(  a2.text()  );  //按钮123
console.log( $(a1).text()  );
console.log(a2[0].innerText);


files[xxx] 就是js的专属用法

如果说非要在Jquery里面调用js的相关方法
方法1:多写点代码 就使用DOM技术来获取JS对象
let file = document.getElementById("file").files[0];

方法2:将jquery对象转成JS对象
let file = $("#file")[0].files[0];

后台校验:和前台校验思路是一致的

需要额外的校验:文件名校验
张三和李四和王五的文件都叫1.jpg   会导致文件的覆盖。

解决方式:只需要保证文件名是独一无二的即可
利用Java自带的UUID 即可
UUID是Java生产一个随机字符串的工具类   可以保证UUID的唯一性

分页查询 

分页查询的基本思想:
假设有351条数据,每页显示5条数据。
需要得到哪些有价值的信息:
1.一共有多少页      --->   需要知道总条数(sql查询)
   总页 ==> 总条数%每页显示的条数==0? 总条数/每页显示的条数 : 总条数/每页显示的条数+1
   总页 ==>  ceil(总条数/每页显示的条数.0)  注意强行让其进行double运行。

2.第几页应该显示哪些数据
分页查询的sql语法:
select * from 表名  limit  a,b ;
a表示从第几条开始  b表示每页显示几条,一般是固定值。

-- 第一页
select * from goods  limit  0,10 ;

-- 第二页
select * from goods  limit  10,10 ;

-- 第三页
select * from goods  limit  20,10 ;

总结:a = (n-1) * b

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值