首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 网页制作-> Javascript教程
一个Jsp初学者的学习过程(八)-JSP教程,Jsp/Servlet
作者:网友供稿 点击:11
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 
一个jsp初学者的学习过程(八)

theunforgiven


第八章 图片文件的操作——blob类型数据的存取和使用第一个servlet

关于这部分内容,我在网上找到一些资料,最后按照我的需求,经过改编得到了下面的代码:
------------------------------upphoto.htm------------------------------------
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=gb2312">
<title>无标题文档</title>
head>

<body>
上传图片:
<form name="form1" method="post" action="upphoto.jsp">
<input name="id" type="text">
(输入一个整数作为该图片的id)<br>
<input size="50" name="file" type="file">
<br>
<input type="submit" name="submit" value="提交">
</form>
<p>&nbsp;</p>
<p>&nbsp;</p>
显示图片:<br>
<br>
<form name="form2" method="post" action="showphoto.jsp">
<input type="text" name="vid">
(输入该图片的id)<br>
<input type="submit" name="submit2" value="提交">
</form>
</body>
</html>
---------------------------------------------------------------------------
upphoto.htm包括两个<form>,form1用于选择要存于数据库的图片;form2用于显示一张数据库里的图片。
-----------------------------upphoto.jsp----------------------------------
<%@ include file="include.inc"%>
<%@ page contenttype="text/html;charset=gb2312"%>
<!doctype html public "-//w3c//dtd html 4.01 transitional//en" "http://www.w3.org/tr/html4/loose.dtd">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=gb2312">
<title>无标题文档</title>
</head>

<body>
<%
int id=integer.parseint(request.getparameter("id"));
request.setcharacterencoding("gb2312");
string f=request.getparameter("file");//得到路径,如:c:\d\e.jpg
string fpath=f.replacefirst("\\\\","\\\\\\\\");//把一个\变成两个\,即路径改成:c:\\d\e.jpg

connection con = null;
preparedstatement pstmt = null;
resultset rs = null;
try
{
class.forname(classforname);//载入驱动程式类别
con=drivermanager.getconnection(servanddb);//建立数据库连接
con.setautocommit(false);
string sql="insert into blb(id,blob) values("+id+",empty_blob())";//数据库里那个表名叫blb,字段的名就叫blob
pstmt=con.preparestatement(sql);//添加一条blob字段为空的记录,
pstmt.executeupdate();
pstmt=null;
sql="select * from blb where id="+id+" for update";
pstmt=con.preparestatement(sql);//查找刚刚添加的那条记录
rs=pstmt.executequery();
if (rs.next())
{
oracle.sql.blob osb = (oracle.sql.blob) rs.getblob("blob");
//到数据库的输出流
outputstream outstream = osb.getbinaryoutputstream();
//这里用一个文件模拟输入流
file file = new file(fpath);
inputstream instream = new fileinputstream(file);
//将输入流写到输出流
byte[] b = new byte[osb.getbuffersize()];
int len = 0;
while ( (len = instream.read(b)) != -1)
{
outstream.write(b, 0, len);
}
//依次关闭(注意顺序)
instream.close();
outstream.flush();
outstream.close();
con.commit();
rs.close();
pstmt.close();
con.close();

out.print("<script>");
out.print("alert(操作成功!);");
out.print("window.location.href=upphoto.htm;");
out.print("</script>");
}//if
}//try
catch(exception e)
{out.print(e);}
%>
</body>
</html>
----------------------------------------------------------------------------
upphoto.jsp对图片进行存入数据库操作。注意需要将得到的文件的路径改变一下格式:c:\d\e.jpg改成c:\\d\e.jpg
------------------------------showphoto.jsp---------------------------------
<%@ page contenttype="text/html;charset=gb2312"%>
<html>
<head>
<title>显示图片</title>
</head>
<body>
<%
string id=request.getparameter("vid");
%>
<table>
<tr>
<td colspan="3"> <img border="1" src="http://ringz/photo?id=<%=id%>"></td>
</tr>
</table>
</body>
</html>
---------------------------------------------------------------------------
showphoto.jsp的这句是关键:src="http://ringz/photo?id=<%=id%>",它说明调用了一个servlet,这个servlet的名字叫photo,而且需要给它传一个值(id)。下面看这个servlet的代码:
---------------------------photoservlet.java------------------------------
package ringz.servlet;
import javax.servlet.*;
import javax.servlet.http.*;
import java.io.*;
import java.util.*;
import java.lang.*;
import java.sql.*;

public class photoservlet extends httpservlet//和javabean一样是“类”,所以类名同样要和文件名一致
{
private string classforname = "oracle.jdbc.driver.oracledriver";
private string servanddb = "jdbc:oracle:thin:name/password@ringz:1521:rock";
connection con = null;
preparedstatement psmt = null;
resultset rs = null;

public void doget(httpservletrequest request, httpservletresponse response) throws servletexception, ioexception
{
int id = integer.parseint(request.getparameter("id"));
try
{
class.forname(classforname);
con=drivermanager.getconnection(servanddb);
con.setautocommit(false);
string sql = "select * from clb where id="+id;
psmt = con.preparestatement(sql);
rs = psmt.executequery();
if (rs.next())
{
blob bb = rs.getblob("blob");
inputstream instream = bb.getbinarystream();
response.setcontenttype("image/*");
outputstream outstream = response.getoutputstream();
byte[] bytes = new byte[1024];
int i=0;
while ( (i = instream.read(bytes)) != -1)
{
outstream.write(bytes, 0, i);
}
instream.close();
outstream.close();
outstream = null;
con.commit();
rs.close();
psmt.close();
con.close();
}//if
}//try
catch (exception ex)
{}
}//doget
}
--------------------------------------------------------------------------
关于servlet的知识请详细参阅有关参考书。下面说编译的事情:servlet像javabean一样需要编译成.class文件,编译方法也和javabean一样。但是我在编译的时候发现出了错误,错误提示如下:
package javax.servlet does not exist
import javax.servlet.*;
^
我分析是少了什么东西造成的,于是在网上查资料,最后终于得出原因:环境变量里没有指出servlet相关的包的位置。解决办法:将原来的环境变量里的classpath添加一条:d:\j2sdk1.4.2_07\lib\servlet.jar;
以我的为例,这是原来的:
classpath——.;d:\j2sdk1.4.2_07\lib\tools.jar;d:\j2sdk1.4.2_07\lib\dt.jar;
这是修改后的:
classpath——.;d:\j2sdk1.4.2_07\lib\tools.jar;d:\j2sdk1.4.2_07\lib\dt.jar;d:\j2sdk1.4.2_07\lib\servlet.jar;
现在顺利的编译出了.class文件,但是同样有问题:文件放在哪?和使用javabean时一样,放在根目录e:\myjsp下的web-inf\classes里,并且可以使用自己的包,比如我的在:e:\myjsp\web-inf\classes\ringz\servlet下。接下来还有一个工作:给这个servlet进行“注册”:在web-inf下建一个web.xml文件,内容大致如下:
----------------------------------web.xml---------------------------------------
<?xml version="1.0" encoding="iso-8859-1"?>
<!doctype web-app
public "-//sun microsystems, inc.//dtd web application 2.3//en"
"http://java.sun.com/dtd/web-app_2_3.dtd">
<web-app>

<display-name>ringzs station</display-name>
<description>
ringzs jsp
</description>

<servlet>
<servlet-name>photoservlet</servlet-name>
<display-name>servlet</display-name>
<servlet-class>ringz.servlet.photoservlet</servlet-class>
</servlet>

<servlet-mapping>
<servlet-name>photoservlet</servlet-name>
<url-pattern>/photo</url-pattern>
</servlet-mapping>

</web-app>
---------------------------------------------------------------------------
其中最重要的是<servlet-name>、<servlet-class>和<url-pattern>,如果你有其他的servlet也需要在这里“注册”一下。关于servlet的配置还有很多其他的内容,比如初始化参数、优先级、映射等等,请学习其他专业资料。顺便说一下:你可以到d:\tomcat 5.0\conf里看看那里那个web.xml文件,我最开始的时候曾经把它复制到我的web-inf下,然后在里面添加了关于photoservlet的内容,结果tomcat服务出错,我猜想是里边的一些内容发生的冲突,但具体是哪些我不清楚,也没有有研究。
现在,配置完毕,可以使用了。



结语

对实例的学习进行到现在,我已经对jsp和java有了初步的了解了,我知道是时候了——该回头找些书看看理论部分了,否则我永远也成不了一个程序员。
学习还要继续,本文就先到这里,假如大家认为我这个东西还有那么一点用处的话,我会把以后的阶段相继写出来;如果没有必要,那就算了吧:)。
请大家指教,扔玉——为了本民族的软件事业。

文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·基于cpld的数字触发电路的设计
·消息队列(Message Queue)简介及其使用-.NET教程,评论及其它
·session_register()出错的解决办法-PHP教程,其它文章
·卫星通信中tcp协议分析改进方法研究
·漫谈Java语言的接口与类型安全-JSP教程,Java技巧及代码
·SQL SERVER2005連接字串中的@3/29-.NET教程,数据库应用
·自创]JCreator安装学习使用方法-数据库专栏,SQL Server
·ASP.NET 数据绑定常用代码-.NET教程,Asp.Net开发
·如何在J2ME的低级界面中轻松实现各种文字的自然分行显示-JSP教程,J2ME开发
·通信设备pac模块式开关电源的原理与维修
最新文章
·photoshop将肖像照片处理为铅笔素描_photoshop教程
·个人网站做联盟广告的几点经验_网赚技巧
·适合与不适合做google adsense的站_网赚技巧
·gg网赚之:怎么样利用e文站轻松月入100刀_网赚技巧
·黄明明归国创业寻觅伙伴:人品好是必要条件_站长访谈
·最普通的7种软文类型_站长访谈
·第九城市ceo朱骏 网海中闯出一片天_站长访谈
·反波访谈:听keso乱弹琴_站长访谈
·人性和互联网_站长心得
·大型网站常用的五种推广方法_站长心得
相关主题
  • 一个Jsp初学者的学习过程(七)-JSP教程,Jsp/Servlet
  • 一个Jsp初学者的学习过程(六)-JSP教程,Jsp/Servlet
  • 一个Jsp初学者的学习过程(五)-JSP教程,Jsp/Servlet
  • 一个Jsp初学者的学习过程(四)-JSP教程,Jsp/Servlet
  • 一个Jsp初学者的学习过程(三)-JSP教程,Jsp/Servlet
  • 西部数码虚拟主机

    友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 自助建站
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机
    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
    关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
    发表评论 打印  刷新     关闭