检测系统工作总结

一、数据库

1、数据库root权限有问题,试着以管理员身份运行cmd,访问root

2、卸载mysql    http://jingyan.baidu.com/article/f96699bbaa8fc1894f3c1b5a.html

通过解压文件安装的mysql,控制面板中没有可卸载内容,直接删除文件夹,之后删除注册表

3、在通过java链接数据库时,在url后加?characterEncoding="UTF-8",解决入库编码问题

4、设计表时注意double类型小数位数的设置


二、路径问题

1、无法直接获取本机路径,只能获取服务器路径

config.getServletContext().getRealPath();获取到的是服务器下的路径。

上传文件就是将文件写入服务器中

下载就是将文件从服务器中写入本地


三、传参

1、在从jsp中传参数到servlet时,form中的enctype=“multipart/form-data” 用来处理上传的文件

这时使用request.getParament("name");是获取不到值得

可以使用commons-fileupload组件实现文件上传,步骤如下:

1、添加jar包:commons-fileupload-x.x.x.jar和commons-io-2.4.jar

2、编写或修改form表单

    1) 提交方式必须是post

    2) 为表单增加属性enctype="multipart/form-data"

    3) 为文件上传单独提供servlet,因为增加enctype属性后,无法使用常规的请求对象来获取提交的数据

3、使用Commons-FileUpload组件实现文件的上传

    1) 确定本次请求是否是文件上传请求

        boolean flag=ServletFileUpload.isMultipartContent(request);

    2) 创建文件上传的工厂对象

        FileItemFactory factory=new DiskFileItemFactory();

    3) 创建ServletFileUpload对象,并将工厂对象作为参数传入

        ServletFileUpload upload=new ServletFileUpload(factory);

    4) 使用上传对象从请求对象中解析出提交的所有表单元素

        List<FileItem> lstForms=upload.parseRequest(request);

    5) 遍历表单元素集合,实现取出表单元素和上传文件      

    //遍历所有表单元素

    for (FileItem fileItem : lstForms) {

        //判断每一个表单元素是否是普通表单

        if(fileItem.isFormField()){

            System.out.println(fileItem.getString("UTF-8"));

        }else{

            //上传前准备工作

                //a、上传后的路径this.getServletContext().getRealPath("/")会出去当前项目在 部署的服务器上的绝对路径

                String path=this.getServletContext().getRealPath("/")+"files/";

                //b、找出要上传的文件的名字

                String fileName=fileItem.getName();

                fileName=fileName.substring(fileName.lastIndexOf("\\")+1);

                //c、上传

                fileItem.write(new File(path+fileName));

                out.println("<h2>"+fileName+"上传成功!</h2>");

    }

}

附件为文件上传的完整代码,包括验证上传的必须是图片!



2、在引css时,放在WEB-INF下时引用不到的,好像是由于WEB-INF是受保护的?

可以放在.jsp同一个文件夹下 用“./css/style.css” 引用,一个点代表.jsp和css文件夹在同一个文件夹下。


3、从jsp向servlet传参时,将接受参数写在request.setCharaterEncoding("UTF-8),后否则参数中中文乱码 


四、PrintWriter writer = response.getWriter();

writer.write("");可以直接写返回的文字描述


五、map按值排序

public class sort{

public static void main(String[] args){

HashMap<String, Double> mao = new HashMap<String, Double>();

ValueComparator bvc = new ValueComparator(map);

TreepMap<String, Double> sorted_map = new TreeMap<String, Double>(bvc);

map.add("A", 99.5);

map.add("B",67.4);

map.add("C",65.4);

map.add("D", 67.3);

sorted_map.putAll(map);

Iterator it = sorted_map.entrySet().iterator();

while(it.hasNext()){

Map.Entry entry = (Map.Entry) it.next();

String key = (String) entry.getKey();

Double value = (Double) getValue();

}

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值