一、数据库
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();
}
}
}