在action或者Servlet中如何得到项目的webRoot路径

String webRootPath = request.getSession().getServletContext().getRealPath("/"); //获得webRoot的路径

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现上传图片到 MySQL 的步骤如下: 1. 在前端页面添加文件上传控件。 2. 在后端编写 Servlet 代码,将上传的图片保存到服务器上的某个目录。 3. 将图片的路径和名称插入到 MySQL 数据库。 4. 在 JSP 页面查询 MySQL 数据库的图片信息,并将其显示在页面上。 以下是实现上传图片到 MySQL 的示例代码: 1. 在前端页面添加文件上传控件 ```html <form method="post" enctype="multipart/form-data" action="UploadServlet"> Select a file: <input type="file" name="file"><br> <input type="submit" value="Upload"> </form> ``` 2. 在后端编写 Servlet 代码,将上传的图片保存到服务器上的某个目录。 ```java @WebServlet("/UploadServlet") @MultipartConfig public class UploadServlet extends HttpServlet { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String savePath = "upload"; File fileSaveDir = new File(savePath); if (!fileSaveDir.exists()) { fileSaveDir.mkdir(); } Part part = request.getPart("file"); String fileName = getFileName(part); part.write(savePath + File.separator + fileName); String filePath = savePath + File.separator + fileName; // 将图片的路径和名称插入到 MySQL 数据库 insertImage(filePath, fileName); } private String getFileName(Part part) { String contentDispositionHeader = part.getHeader("content-disposition"); String[] elements = contentDispositionHeader.split(";"); for (String element : elements) { if (element.trim().startsWith("filename")) { return element.substring(element.indexOf('=') + 1).trim().replace("\"", ""); } } return null; } private void insertImage(String filePath, String fileName) { try { Class.forName("com.mysql.jdbc.Driver"); Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "password"); String sql = "INSERT INTO images (name, path) VALUES (?, ?)"; PreparedStatement pstmt = conn.prepareStatement(sql); pstmt.setString(1, fileName); pstmt.setString(2, filePath); pstmt.executeUpdate(); pstmt.close(); conn.close(); } catch (Exception e) { e.printStackTrace(); } } } ``` 3. 在 JSP 页面查询 MySQL 数据库的图片信息,并将其显示在页面上。 ```html <% Connection conn = null; Statement stmt = null; ResultSet rs = null; try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "password"); stmt = conn.createStatement(); String sql = "SELECT * FROM images"; rs = stmt.executeQuery(sql); while(rs.next()) { String name = rs.getString("name"); String path = rs.getString("path"); %> <img src="<%=path%>/<%=name%>" /><br> <% } } catch (Exception e) { e.printStackTrace(); } finally { try { if (rs != null) rs.close(); if (stmt != null) stmt.close(); if (conn != null) conn.close(); } catch (SQLException e) { e.printStackTrace(); } } %> ``` 注意:上述代码仅供参考,需要根据实际业务需求进行修改和完善。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值