Socket+JDBC+IO实现Java文件上传下载器DEMO详解
该demo实现的功能有:
1.用户注册:
注册时输入两次密码,若两次输入不一致,则注册失败,需要重新输入。若用户名被注册过,则提示用户重新输入用户名;
2.用户登录:
需要验证数据库中是否有对应的用户名和密码,若密码输错三次,则终止用户的登录操作;
3.文件上传:
从本地上传文件到文件数据库中
4.文件下载:
从数据库中下载文件到本地
5.文件更新:
根据id可更新数据库中的文件名
6.文件删除:
根据id删除数据库中某一个文件
7.看数据库所有文件;
8.查看文件(根据用户名);
9.查看文件(根据文件id);
代码分为如下四个部分:Entity,Service,Socket,Util
实体包Entity中主要存放用户实体和文件实体
User类:
packageEntity; importjava.io.Serializable; /** *用户类 *@authorAdministrator * */ publicclassUserimplementsSerializable{ //属性 privateintid; privateStringusername; privateStringpassword; //方法 //构造方法 publicUser(){ super(); } publicUser(Stringusername,Stringpassword){ super(); this.username=username; this.password=password; } //Getter,Setter方法 publicintgetId(){ returnid; } publicvoidsetId(intid){ this.id=id; } publicStringgetUsername(){ returnusername; } publicvoidsetUsername(Stringusername){ this.username=username; } publicStringgetPassword(){ returnpassword; } publicvoidsetPassword(Stringpassword){ this.password=password; } }
文件类:
packageEntity; importjava.io.Serializable; importjava.util.Arrays; /** *文件实体类 *@authorAdministrator * */ publicclassFileEntityimplementsSerializable{ //属性 privateintfid; privateStringusername;//用户名,方便查看某个用户上传的文件 publicStringgetUsername(){ returnusername; } publicvoidsetUsername(Stringusername){ this.username=username; } privateStringfname; privatebyte[]fcontent; //方法 //构造方法 publicFileEntity(){ super(); } publicFileEntity(Stringusername,Stringfname,byte[]fcontent){ super(); this.username=username; this.fname=fname; this.fcontent=fcontent; } //Getter,Setter方法 publicintgetFid(){ returnfid; } publicvoidsetFid(intfid){ this.fid=fid; } publicStringgetFname(){ returnfname; } publicvoidsetFname(Stringfname){ this.fname=fname; } publicbyte[]getFcontent(){ returnfcontent; } publicvoidsetFcontent(byte[]fcontent){ this.fcontent=fcontent; } @Override publicStringtoString(){ return"FileEntity[fid="+fid+",username="+username+",fname=" +fname+"]"; } }
Service包:包括用户服务类和文件服务类
UserSevice类包括了与用户相关的注册和登录功能相关的方法
packageService; importjava.sql.Connection; importjava.sql.PreparedStatement; importjava.sql.ResultSet; importjava.sql.SQLException; importUtil.DBUtil; importEntity.User; publicclassUserService{ privateConnectionconn=null; privatePreparedStatementpstmt=null; privateResultSetrs=null; /** *登陆 */ publicbooleanlogin(Useruser){ Stringsql="select*fromtb_userwhereusername=?andpassword=?"; try{ conn=DBUtil.getConnection(); pstmt=conn.prepareStatement(sql); pstmt.setString(1,user.getUsername()); pstmt.setString(2,user.getPassword()); rs=pstmt.executeQuery(); if(rs.next()){ returntrue; } }catch(SQLExceptione){ e.printStackTrace(); }finally{ DBUtil.CloseAll(rs,pstmt,conn); } returnfalse; } /** *注册 */ publicvoidregister(Useruser){ Stringsql="insertintotb_user(username,password)value(?,?)"; try{ conn=DBUtil.getConnection(); pstmt=conn.prepareStatement(sql); pstmt.setString(1,user.getUsername()); pstmt.setString(2,user.getPassword()); pstmt.executeUpdate(); }catch(SQLExceptione){ e.printStackTrace(); }finally{ DBUtil.CloseAll(rs,pstmt,conn); } } /** *查找tb_user,查看用户是否已经注册过 */ publicbooleanqueryByUsername(Stringusername){ conn=DBUtil.getConnection(); Stringsql="select*fromtb_userwhereusername=?"; try{ pstmt=conn.prepareStatement(sql); pstmt.setString(1,username); rs=pstmt.executeQuery(); if(rs.next()){ //说明已经被注册过,要求重新填写用户名 returntrue; } }catch(SQLExceptione){ e.printStackTrace(); } returnfalse; } }
文件服务类:
packageService; importjava.io.ByteArrayInputStream; importjava.io.File; importjava.io.FileInputStream; importjava.io.FileOutputStream; importjava.io.IOException; importjava.sql.Connection; importjava.sql.PreparedStatement; importjava.sql.ResultSet; importjava.sql.SQLException; importjava.util.ArrayList; importjava.util.List; importjava.util.Scanner; importEntity.FileEntity; importUtil.DBUtil; publicclassFileService{ privateConnectionconn=null; privatePreparedStatementpstmt=null; privateResultSetrs=null; /** *保存文件到数据库,类似用户的注册功能 *@paramfileEntity */
以上所述是小编给大家介绍的Socket+JDBC+IO实现Java文件上传下载器DEMO详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!