javaapplet js調用applet實現上傳下載

轉自:http://writeblog.csdn.net/blog/714839

1.上傳的代碼:
applet代碼:
package applet;

import java.applet.Applet;
import java.io.*;
import java.net.HttpURLConnection;
import java.net.URL;
import java.net.URLEncoder;

//本地文件上傳(與Servlet交互)
public class AppInt extends Applet { 

private String filePath;
private String fileName;
private String url;

private boolean bl=false;
public String getFilePath() {
  return filePath;
}

public void setFilePath(String filePath) {
  this.filePath = filePath;
  System.out.println(this.filePath);
}

public String getFileName() {
  return fileName;
}

public void setFileName(String fileName) {
  this.fileName = fileName;
  System.out.println(this.fileName);
}

public String getUrl() {
  return url;
}

public void setUrl(String url) {
  this.url = url;
  System.out.println(this.url);
}

public void setBl(){
  this.bl=true;
  System.out.println(this.bl);
  send();
}

public void init() {  
  if(this.bl){
  send();
  }


public void send() {
  {

  try {
  String filePath=getFilePath();
  String fileName =getFileName();  
  String urlstring=getUrl();

  System.out.println(filePath+"*****");
  //網絡路徑很重要
  URL url1 = new URL(urlstring+"?fileName="+URLEncoder.encode(fileName,"utf-8"));

  //打開打開SOCKET鏈接
   
  HttpURLConnection conn = (HttpURLConnection) url1
  .openConnection();
  conn.setRequestMethod("POST");
  conn.setAllowUserInteraction(true);
  conn.setDoInput(true);
  conn.setDoOutput(true);
  conn.setUseCaches(true);
  conn.setRequestProperty("Content-Type", "application/octet-stream");

  
  File jpgFile = new File(filePath);
  if (jpgFile.isFile()) {
  // 建立文件的輸入流
  FileInputStream fileInputStream = null;
  fileInputStream = new FileInputStream(jpgFile);
  BufferedInputStream bis = new BufferedInputStream(
  fileInputStream);
  OutputStream os = conn.getOutputStream();
  BufferedOutputStream bos = new BufferedOutputStream(os);
  int len = 0;
  byte[] bty = new byte[4096];
  while ((len = bis.read(bty, 0, 4096)) != -1) {
  bos.write(bty, 0, len);
  bos.flush();

  }
  bos.close();
  bis.close();
  System.out.println(conn.getContentType() + ": "+ conn.getResponseCode());
  }
  } catch (Exception e) {
  e.printStackTrace();

  }

  }
}
}

對應的Servlet代碼:

package servlet;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.PrintWriter;
import java.util.Calendar;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.DB.DBconnect;

public class Receive extends HttpServlet {


public Receive() {
  super();
}


public void destroy() {
  super.destroy(); // Just puts "destroy" string in log
  // Put your code here
}


public void doGet(HttpServletRequest request, HttpServletResponse response)
  throws ServletException, IOException {

}


public void doPost(HttpServletRequest request, HttpServletResponse response)
  throws ServletException, IOException {

  // PrintWriter out=response.getWriter();
  InputStream in = request.getInputStream();  
  //System.out.print("qqqq");

  
   
  String name=new String(request.getParameter("fileName").getBytes(),"utf-8");
   
  String nn=new String(name.getBytes("ISO8859-1"),"utf-8");
  System.out.println("文件名:"+name+"******"+nn);
   
  String tr=name.substring(name.lastIndexOf("."),name.length());
  
  // 根據時間得文件名
  Calendar calendar = Calendar.getInstance();
  String filename = String.valueOf(calendar.getTimeInMillis())
  +tr;
   
  System.out.println("服務器,文件名:"+name);
   
  File f = new File("C://imgrec//"+filename); 
  String path="c:/imgrec/"+filename;
  FileOutputStream fos = new FileOutputStream(f);

  byte[] b = new byte[1024 * 1024]; 
  int bytes, sumBytes = 0;

  while (true) { 
  bytes = in.read(b); 
  if (bytes <= 0) 
  break; 
  sumBytes += bytes; 
  fos.write(b, 0, bytes); 
  } 
  fos.close(); 
  in.close(); 
   
   
  /*
  * 保存上傳記錄
  */
  DBconnect dao=new DBconnect();
  String sql="insert into fileList(fileName,filePath,name) values('"+filename+"','"+path+"','"+name+"')";
  dao.save(sql);
  dao.close();
   
  }


public void init() throws ServletException {
}

}

JSP頁面:

<%@ page language="java" import="java.util.*,applet.GLAppInt" pageEncoding="utf-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
   
   
  <title>test.jsp</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">

</head>

<body >
<APPLET CODE = "applet.GLAppInt.class" archive="applet.jar" height="90%" MAYSCRIPT> 
<param name="path" value="E:/test/upload">
</APPLET> 
<script type="text/javascript">
function saveHtml(){
var filePath=document.applets[0].getAn();
var fileName=document.applets[0].getName();
//alert(fileName);
document.location="show.jsp?filePath="+filePath+"&fileName="+fileName;
}


</script>



</body>


</html>

//*************************

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
  <base href="<%=basePath%>">
   
  <title>My JSP 'show.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">
-->

</head>

<body> 
   
   
  <%
  String url=request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+"/appUpFile/servlet/Receive" ;
  String filePath=request.getParameter("filePath");
   
  if(filePath.length()>0){
  String fileName=request.getParameter("fileName");
  String[] fPath=filePath.split(",");
  String[] fName=fileName.split(",");
   
   
  %>
  <div>
  <APPLET CODE = "applet.AppInt.class" archive="ctr.jar" mayscript height="1" width="1">  
  </APPLET>
  <script type="text/javascript">
  function tsb(n){
  var fn=document.getElementById('fn'+n).value;
  var fp=document.getElementById('fp'+n).value;
  var ul='<%=url%>';
  document.applets[0].setFileName(fn);
  document.applets[0].setFilePath(fp);
  document.applets[0].setUrl(ul);
  document.applets[0].setBl();
  }
  </script>
  </div>
   
  <div align='center'>本地文件上傳</div>
  <form action="">
  <table>
  <tr>
  <td>文件名</td>
  <td>路徑</td>
  <td>上傳</td>
  </tr>
  <%
  for(int i=0;i<fName.length;i++){
  String fp=new String(fPath[i].getBytes("ISO-8859-1"),"utf-8");
  String fn=new String(fName[i].getBytes("ISO-8859-1"),"utf-8");
   
  %>
  <tr>
  <td><input type="hidden" name="fn<%=i %>" id="fn<%=i %>" value="<%=fn %>"><%=fn %></td>
  <td><input type="hidden" name="fp<%=i %>" id="fp<%=i %>" value="<%=fp %>"><%=fp %></td>  
  <td><input type="button" name="sb" value="上傳" οnclick="tsb('<%=i %>')">
  </td>
  </tr>
  <%
  } 
  %>
  </table>
  </form>
<%
}
%>

</body>
</html>

數據庫設計:

fileList表:有4個字段 id,fileName,filePath ,name

package com.DB;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;


public class DBconnect {
public static Connection conn = null;

public DBconnect() {
  this.conn = getMySqlConnection();
}

public static Connection getMySqlConnection() {
  String url = null;
  try {
  Class.forName("com.mysql.jdbc.Driver");
  url = "jdbc:mysql://localhost:3306/listenle?useUnicode=true&characterEncoding=UTF-8";
  conn = DriverManager.getConnection(url, "root", "rufeng8848");
  } catch (Exception e) {
  e.printStackTrace();
  }
  return conn;
}

/*
* 插入表fileList 給每一次上傳的文件做好記錄
* 記錄上傳
*/
public void save(String sql){
  Statement st=null;
  
  try {
  st=conn.createStatement();
  st.execute(sql);
  } catch (SQLException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
  }
}
/*
* 取出fileList表中 文件名,路徑 
* 便於下載
* 返回類型爲
*/
public ResultSet findAll(){
  ResultSet rs=null;
  Statement st=null;
  String sql="select * from fileList";
  try {
  st=conn.createStatement();
  rs=st.executeQuery(sql);
  } catch (SQLException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
  }
  return rs;
}
/*
* 關閉鏈接
*/
public void close() {
  try {
  conn.close();
  } catch (SQLException e) {
  e.printStackTrace();
  System.out.println("關閉異常");
  }
}
}
這樣就可以上傳了。

經過測試發現,JS調用applet報java.security.accesscontrolexception異常。

原來是安全機制的問題。在客戶端修改一下java的安全機制就可以了。

  總結:在文件的傳輸中是流的形式存在的,在硬盤上是文件的形式存在的。我們要做的只是通過HttpServletRequest和HttpServletResponse,或者是response和request來發送流和讀取流。以及把文件轉換成流或把流轉換成文件的操作。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章