jsp中ajax表单提交到另外一个jsp再返回来

这个没什么难度,其实说到底jsp也是一个servlet,只是我们不建议把业务的处理以及控制放在jsp里面,但是有时候项目中没办法,

必须得用到所以只能用jsp处理

 

下面是具体代码

 

初始的jsp中:

<body>
  <form action="" id="form1"
   enctype="multipart/form-data" method="post">
   文本1:
   <input type="text" name="text1" value="文本1">
   <br>
   文件2:
   <input type="text" name="text2" value="文本2">
   <br>
   文件1:
   <input type="file" name="file1">
   <br>
   文件2:
   <input type="file" name="file2">
   <br>
   文件3:
   <input type="file" name="file3">
   <br>
   <input type="button" οnclick="tijiao()" value="开始上传">
  </form>

 </body>

 

js代码:

function tijiao(){
   
   $.ajax( { 
                    type : "POST", 
                    url : "showImg.jsp", 
                    data: $('#form1').serialize(),  //整个表单提交
                    success : function(msg) {
                     alert(111)
                    } 
                });  
   
  }

 

所要跳转的jsp:

<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";

response.getWriter().print("true");//这段代码是用于跳回原来页面的
%>


<html>
  <head>

   
    <title>My JSP 'showImg.jsp' starting page</title>
   
 <meta http-equiv="pragma" content="no-cache">
 <meta http-equiv="cache-control" content="no-cache">
 <meta http-equiv="expires" content="0">   
 <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
 <meta http-equiv="description" content="This is my page">
 <!--
 <link rel="stylesheet" type="text/css" href="styles.css">
 -->
<script type="text/javascript" src="../js/jquery-1.7.2.min.js"></script>

  </head>
 
  <body>
    
     <div id="imgDiv">
      <img id="img1"  src=''></img><br>
      <img id="img2" src=''></img><br>
      <img id="img3" src=''></img><br>
     </div>
  </body>
</html>
<script language="javascript" type="text/javascript">
 
 var fileUrl = "../"+"<%=request.getParameter("fileURL1")%>" ;
 var fileUr2 = "../"+"<%=request.getParameter("fileURL2")%>" ;
 var fileUr3 = "../"+"<%=request.getParameter("fileURL3")%>" ;
 //alert(fileUrl+"+"+fileUr2+"+"+fileUr3)
 document.getElementById("img1").src = fileUrl;
 document.getElementById("img2").src = fileUr2;
 document.getElementById("img3").src = fileUr3;
 //alert("<%=basePath%>");

</script>

 

 

这里面我没做任何的业务处理,只是实现了来回的跳转,具体的业务可以自己新增

 

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用HTML5的FormData对象来实现多文件上传,然后使用Ajax将数据发送到服务器。在服务器端,您可以使用Java的Servlet来处理上传的文件,并将文件路径保存到数据库。以下是一个简单的示例代码: HTML代码: ```html <form id="myForm" enctype="multipart/form-data"> <input type="file" name="file1"> <input type="file" name="file2"> <input type="button" value="Upload" onclick="uploadFiles()"> </form> ``` JavaScript代码: ```javascript function uploadFiles() { var form = document.getElementById("myForm"); var formData = new FormData(form); var xhr = new XMLHttpRequest(); xhr.open("POST", "uploadServlet", true); xhr.onreadystatechange = function() { if (xhr.readyState == 4 && xhr.status == 200) { alert(xhr.responseText); } }; xhr.send(formData); } ``` Java代码: ```java @WebServlet("/uploadServlet") @MultipartConfig public class UploadServlet extends HttpServlet { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String file1Path = saveFile(request.getPart("file1")); String file2Path = saveFile(request.getPart("file2")); // 将文件路径保存到数据库 // ... response.getWriter().write("Files uploaded successfully!"); } private String saveFile(Part part) throws IOException { String fileName = getFileName(part); String filePath = "C:/uploads/" + fileName; part.write(filePath); return filePath; } private String getFileName(Part part) { String contentDisposition = part.getHeader("content-disposition"); String[] tokens = contentDisposition.split(";"); for (String token : tokens) { if (token.trim().startsWith("filename")) { return token.substring(token.indexOf("=") + 2, token.length() - 1); } } return ""; } } ``` 请注意,此示例代码仅供参考,您需要根据自己的需求进行修改和优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值