提交项目接口

This commit is contained in:
cyk
2023-07-08 17:51:11 +08:00
parent 4145be1952
commit 4fc9728619
6 changed files with 451 additions and 0 deletions

View File

@@ -0,0 +1,26 @@
package com.hellogithub.dao;
import com.hellogithub.utils.JdbcUtils;
import org.apache.commons.dbutils.QueryRunner;
import java.sql.Connection;
import java.sql.SQLException;
public class projectCategoryDao {
public int insertProject(int userId,int projectId)
{
int num ;
try {
Connection conn = JdbcUtils.getConnection();
QueryRunner runner = new QueryRunner();
String sql ="INSERT into project_category (userId,projectId) VALUES (?,?)";
num = runner.update(conn, sql,userId,projectId);
conn.close();
} catch (SQLException e) {
throw new RuntimeException(e);
}
return num ;
}
}

View File

@@ -265,4 +265,48 @@ public class projectDao {
}
return num;
}
public int insertProject(int userId,String projectName,String projectUrl,String projectIco,String projectTitle,String projectDescription,String submitTime,int categoryId)
{
int num ;
try {
Connection conn = JdbcUtils.getConnection();
QueryRunner runner = new QueryRunner();
String sql ="INSERT into project (userId,projectName,projectUrl,projectIco,projectTitle,projectDescription,startNum,submitTime,categoryId,isValid,periodicals,lookCount) VALUES (?,?,?,?,?,?,0,?,?,1,0,0)";
num = runner.update(conn, sql,userId,projectName,projectUrl,projectIco,projectTitle,projectDescription,submitTime,categoryId);
conn.close();
} catch (SQLException e) {
throw new RuntimeException(e);
}
return num ;
}
public int updateProject(String projectName,String fileAddress)
{
int num ;
try {
Connection conn = JdbcUtils.getConnection();
QueryRunner runner = new QueryRunner();
String sql ="update project set fileAddress = ? where projectName = ? and isValid = 1";
num = runner.update(conn, sql,projectName,fileAddress);
conn.close();
} catch (SQLException e) {
throw new RuntimeException(e);
}
return num ;
}
public projectEntity selectProByProName(String projectName ) {
projectEntity projectEntity;
try {
Connection conn = JdbcUtils.getConnection();
QueryRunner runner = new QueryRunner();
String sql = "select * from project where isValid = 1 and projectName = ?";
projectEntity = runner.query(conn, sql, new BeanHandler<>(projectEntity.class),projectName);
conn.close();
} catch (SQLException e) {
throw new RuntimeException(e);
}
return projectEntity;
}
}

View File

@@ -180,4 +180,5 @@ public class projectEntity {
public void setUserUri(String userUri) {
this.userUri = userUri;
}
}

View File

@@ -7,6 +7,8 @@ import com.hellogithub.dao.*;
import com.hellogithub.entity.*;
import java.math.BigDecimal;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.*;
@@ -21,6 +23,8 @@ public class projectService {
private commentDao commentDao = new commentDao();
private UserDao userDao = new UserDao();
private projectCategoryDao projectCategoryDao = new projectCategoryDao();
/**
* 按照期刊号查询
*/
@@ -234,5 +238,42 @@ public class projectService {
}
return JSONObject.toJSONString(projectEntityList);
}
public int insertProject(String username,String projectName,String projectUrl,String projectIco,String projectTitle,String projectDescription,List<Integer> categoryIdList){
if(projectDao.selectProByProName(projectName) != null){
return 0;
}
String mes="success";
int pnum;
int flag = 1 ;
DateFormat format = new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss" );
Date time = new Date();
String submitTime = format.format(time).toString();
int categoryId = categoryIdList.get(0);
int userId = userDao.selectIdByName(username);
for(int i=0;i<categoryIdList.size();i++)
{
int id = categoryIdList.get(i);
int num = projectCategoryDao.insertProject(userId,id);
if(num == 0 )
{
flag=0;
break;
}
}
pnum = projectDao.insertProject(userId,projectName,projectUrl,projectIco,projectTitle,projectDescription,submitTime,categoryId);
if(pnum == 0 )
{
flag=0;
}
return flag ;
}
public int updateProject(String projectName,String fileAddress)
{
int num = projectDao.updateProject(projectName,fileAddress);
return num ;
}
}

View File

@@ -0,0 +1,249 @@
package com.hellogithub.servlet;
import com.alibaba.fastjson.JSONObject;
import com.hellogithub.entity.userEntity;
import com.hellogithub.service.UserService;
import com.hellogithub.service.projectService;
import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.FileUploadBase;
import org.apache.commons.fileupload.ProgressListener;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.*;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.UUID;
@WebServlet("/commitProjectFile")
public class commitProjectFileServlet extends HttpServlet {
private UserService userService = new UserService();
private projectService projectService = new projectService();
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
int num = 1;
response.setCharacterEncoding("UTF-8");
response.setContentType("text/html; charset=utf-8");
// 设置响应头允许ajax跨域访问
String curOrigin = request.getHeader("Origin");
response.setHeader("Access-Control-Allow-Origin", curOrigin == null ? "true" : curOrigin);
response.setHeader("Access-Control-Allow-Credentials", "true");
response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE, HEAD");
response.setHeader("Access-Control-Max-Age", "3600");
response.setHeader("Access-Control-Allow-Headers", "access-control-allow-origin, authority, content-type, version-info, X-Requested-With");
response.setContentType("application/json;charset=UTF-8");
PrintWriter writer = response.getWriter();
HttpSession session = request.getSession();
// userEntity userEntity ;
String projectName = request.getParameter("projectName");
//得到上传文件的保存目录将上传的文件存放于WEB-INF目录下不允许外界直接访问保证上传文件的安全
String savePath = this.getServletContext().getRealPath(File.separator+"WEB-INF"+File.separator+"upload");
savePath= this.getServletContext().getRealPath(File.separator+"WEB-INF"+File.separator+"upload").replace("\\out\\artifacts\\helloGithub_war_exploded\\WEB-INF\\upload","\\web\\projectFile");
System.out.println(savePath);
//上传时生成的临时文件保存目录
String tempPath = this.getServletContext().getRealPath(File.separator+"WEB-INF"+File.separator+"tmp");
File tmpFile = new File(tempPath);
if (!tmpFile.exists()) {
//创建临时目录
tmpFile.mkdir();
}
//消息提示
String message = "";
String saveFilename="";
try{
//使用Apache文件上传组件处理文件上传步骤
//1、创建一个DiskFileItemFactory工厂
DiskFileItemFactory factory = new DiskFileItemFactory();
//设置工厂的缓冲区的大小,当上传的文件大小超过缓冲区的大小时,就会生成一个临时文件存放到指定的临时目录当中。
factory.setSizeThreshold(1024*100);//设置缓冲区的大小为100KB如果不指定那么缓冲区的大小默认是10KB
//设置上传时生成的临时文件的保存目录
factory.setRepository(tmpFile);
//2、创建一个文件上传解析器
ServletFileUpload upload = new ServletFileUpload(factory);
//监听文件上传进度
upload.setProgressListener(new ProgressListener(){
public void update(long pBytesRead, long pContentLength, int arg2) {
System.out.println("文件大小为:" + pContentLength + ",当前已处理:" + pBytesRead);
/**
* 文件大小为14608,当前已处理4096
文件大小为14608,当前已处理7367
文件大小为14608,当前已处理11419
文件大小为14608,当前已处理14608
*/
}
});
//解决上传文件名的中文乱码
upload.setHeaderEncoding("UTF-8");
//3、判断提交上来的数据是否是上传表单的数据
if(!ServletFileUpload.isMultipartContent(request)){
//按照传统方式获取数据
return;
}
//设置上传单个文件的大小的最大值目前是设置为1024*1024字节也就是10MB
// upload.setFileSizeMax(1024*1024*1024*1);
//设置上传文件总量的最大值,最大值=同时上传的多个文件的大小的最大值的和目前设置为10MB
upload.setSizeMax(1024*1024*1024*10);
//4、使用ServletFileUpload解析器解析上传数据解析结果返回的是一个List<FileItem>集合每一个FileItem对应一个Form表单的输入项
List<FileItem> list = upload.parseRequest(request);
for(FileItem item : list){
//如果fileitem中封装的是普通输入项的数据
if(item.isFormField()){
String name = item.getFieldName();
//解决普通输入项的数据的中文乱码问题
String value = item.getString("UTF-8");
//String value = new String(name.getBytes("iso8859-1"),"UTF-8");
System.out.println(">>>>>>>>>>"+name + "=" + value);
}else{
//如果fileitem中封装的是上传文件
//得到上传的文件名称,
String filename = item.getName();
//filename = item.getString("UTF-8");
//filename = new String(filename.getBytes("iso8859-1"),"UTF-8");
System.out.println(filename);
if(filename==null || filename.trim().equals("")){
continue;
}
//注意:不同的浏览器提交的文件名是不一样的,有些浏览器提交上来的文件名是带有路径的,如: c:\a\b\1.txt而有些只是单纯的文件名1.txt
//处理获取到的上传文件的文件名的路径部分,只保留文件名部分
filename = filename.substring(filename.lastIndexOf(File.separator)+1);
//得到上传文件的扩展名
String fileExtName = filename.substring(filename.lastIndexOf(".")+1);
//如果需要限制上传的文件类型,那么可以通过文件的扩展名来判断上传的文件类型是否合法
System.out.println("上传的文件的扩展名是:"+fileExtName);
//获取item中的上传文件的输入流
InputStream in = item.getInputStream();
//得到文件保存的名称
saveFilename = makeFileName(filename);
//得到文件的保存目录
String realSavePath = makePath(saveFilename, savePath);
System.out.print(realSavePath+"\\"+saveFilename);
//创建一个文件输出流
FileOutputStream out = new FileOutputStream(realSavePath +File.separator+ saveFilename);
//创建一个缓冲区
byte buffer[] = new byte[1024];
//判断输入流中的数据是否已经读完的标识
int len = 0;
//循环将输入流读入到缓冲区当中,(len=in.read(buffer))>0就表示in里面还有数据
while((len=in.read(buffer))>0){
//使用FileOutputStream输出流将缓冲区的数据写入到指定的目录(savePath + "\\" + filename)当中
out.write(buffer, 0, len);
}
//关闭输入流
in.close();
//关闭输出流
out.close();
//删除处理文件上传时生成的临时文件
item.delete();
message = "文件上传成功!";
num = projectService.updateProject(projectName,realSavePath+"\\"+saveFilename);
}
}
}catch (FileUploadBase.FileSizeLimitExceededException e) {
e.printStackTrace();
setResultError("单个文件超出最大值",writer);
return;
}catch (FileUploadBase.SizeLimitExceededException e) {
e.printStackTrace();
setResultError("上传文件的总的大小超出限制的最大值",writer);
return;
}catch (Exception e) {
message= "文件上传失败!";
setResultError("文件上传失败",writer);
e.printStackTrace();
}
if(num == 0)
{
setResultError("文件提交失败",writer);
}
// writer.println(saveFilename);
// setResultOK(message,writer);
}
/**
* @Method: makeFileName
* @Description: 生成上传文件的文件名文件名以uuid+"_"+文件的原始名称
* @Anthor:
* @param filename 文件的原始名称
* @return uuid+"_"+文件的原始名称
*/
private String makeFileName(String filename){ //2.jpg
//为防止文件覆盖的现象发生,要为上传文件产生一个唯一的文件名
return UUID.randomUUID().toString() + "_" + filename;
// return filename;
}
/**
* 为防止一个目录下面出现太多文件要使用hash算法打散存储
* @Method: makePath
* @Description:
* @Anthor:
*
* @param filename 文件名,要根据文件名生成存储目录
* @param savePath 文件存储路径
* @return 新的存储目录
*/
private String makePath(String filename,String savePath){
String dir = savePath;
//File既可以代表文件也可以代表目录
File file = new File(dir);
//如果目录不存在
if(!file.exists()){
//创建目录
file.mkdirs();
}
return dir;
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
public void setResult(Integer code, String msg, PrintWriter writer) {
HashMap<String, Object> result = new HashMap<>();
result.put("code", code);
result.put("msg", msg);
String jsonString = JSONObject.toJSONString(result);
writer.println(jsonString);
writer.close();
}
public void setResultError(String msg, PrintWriter writer) {
setResult(500, msg, writer);
}
public void setResultOK(String msg, PrintWriter writer) {
setResult(200, msg, writer);
}
}

View File

@@ -0,0 +1,90 @@
package com.hellogithub.servlet;
import com.alibaba.fastjson.JSONObject;
import com.hellogithub.entity.userEntity;
import com.hellogithub.service.projectService;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
@WebServlet("/commitProject")
public class commitProjectServlet extends HttpServlet {
private projectService projectService = new projectService();
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doPost(req, resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
resp.setCharacterEncoding("UTF-8");
resp.setContentType("text/html; charset=utf-8");
// 设置响应头允许ajax跨域访问
String curOrigin = req.getHeader("Origin");
resp.setHeader("Access-Control-Allow-Origin", curOrigin == null ? "true" : curOrigin);
resp.setHeader("Access-Control-Allow-Credentials", "true");
resp.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE, HEAD");
resp.setHeader("Access-Control-Max-Age", "3600");
resp.setHeader("Access-Control-Allow-Headers", "access-control-allow-origin, authority, content-type, version-info, X-Requested-With");
resp.setContentType("application/json;charset=UTF-8");
HttpSession session = req.getSession();
userEntity userEntity;
userEntity =(userEntity) session.getAttribute("user");
PrintWriter writer = resp.getWriter();
if(userEntity == null)
{
setResultError("用户未登录",writer);
}else{
String username = userEntity.getUserName();
String projectName = req.getParameter("projectName");
String projectIco = req.getParameter("projectIco");
String projectUrl = req.getParameter("projectUrl");
String projectTitle = req.getParameter("projectTitle");
String projectDescription = req.getParameter("projectDescription");
String [] categoryIdList = req.getParameterValues("projectDescription");
List<Integer> integers = new ArrayList<>();
for (String s : categoryIdList) {
integers.add(Integer.parseInt(s));
}
int flag = projectService.insertProject(username,projectName,projectUrl,projectIco,projectTitle,projectDescription,integers);
if(flag == 0)
{
setResultError("插入失败",writer);
}
else{
setResultOK("插入成功",writer);
}
}
}
public void setResult(Integer code, String msg, PrintWriter writer) {
HashMap<String, Object> result = new HashMap<>();
result.put("code", code);
result.put("msg", msg);
String jsonString = JSONObject.toJSONString(result);
writer.println(jsonString);
writer.close();
}
public void setResultError(String msg, PrintWriter writer) {
setResult(500, msg, writer);
}
public void setResultOK(String msg, PrintWriter writer) {
setResult(200, msg, writer);
}
}