JDeveloper做成Servlet

这几天学着用 JDeveloper 做了一个 Servlet 很简单的小例子:
要将 Webコンテンツ → WEB-INF 下的 web.xml 文件进行 deploy (WARデプロイメント.プロファイルの作成),在 リソース 下生成 webapp1.deploy 文件,然后在 Package下面作成Java文件。

Servlet.java:
package servlet1;

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.*;
import java.io.BufferedReader;
import javax.servlet.*;
import javax.servlet.http.*;

public class Servlet1 extends HttpServlet {
private static final String CONTENT_TYPE = "text/html; charset=Shift_JIS";

public void init(ServletConfig config) throws ServletException {
super.init(config);
}

public void doPost(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
response.setContentType(CONTENT_TYPE);
PrintWriter out = response.getWriter();

String id = request.getParameter("theid");
String sql = request.getParameter("thesql");

/*
* userName:servlets
* passWord:servlets
* host:172.17.3.111
* SID:STUDY
* driver:thin
* JDBCport:1521
*/
Connection con = connectToDB("servlets", "servlets", "172.17.3.111", "STUDY");
ResultSet rs=null;
Statement stmt =null;
try{
stmt = con.createStatement();
rs = stmt.executeQuery(sql + id);
generateHTML(out, rs);
rs.close();
stmt.close();
con.close();
} catch (SQLException e) {
System.out.println(e.getMessage());
} catch(Exception ex) {
System.out.println(ex.getMessage());
}
out.close();
}

public Connection connectToDB(String userName, String passWord, String hostName, String sid) {
Connection con = null;
try{
Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
con = DriverManager.getConnection("jdbc:oracle:thin:@" + hostName + ":1521:" + sid, userName, passWord);
} catch (java.sql.SQLException e) {
System.out.println("connect error " + e);
} catch (java.lang.ClassNotFoundException e) {
System.out.println("driver not found");
System.out.println("driver " + e);
} catch (IllegalAccessException e) {
System.out.println(e.getMessage());
} catch (InstantiationException e) {
System.out.println(e.getMessage());
}
return con;
}

public void generateHTML(PrintWriter out, ResultSet rs) {
out.println("<html>");
out.println("<head>");
out.println("<title>Servlet1</title>");
out.println("</head>");
out.println("<body>");
try {
while (rs.next()){
out.println("<table width=20% cellspacing=10 cellpadding=5>");
//out.println("<caption align=center>Ser Infor</caption>");
out.println("<tr><td>ID :</td>");
out.println("<td>" + rs.getString("ID") + "</td></tr>");
out.println("<tr><td>Value :</td>");
out.println("<td>" + rs.getString("VALUE") + "</td></tr>");
out.println("<tr><td>Name :</td>");
out.println("<td>" + rs.getString("NAME") + "</td></tr>");
out.println("</table>");
}
} catch (SQLException e) {
out.println(e);
}
out.println("</body>");
out.println("</html>");
}
}

HTML文件:
<HTML>
<BODY>
<FORM METHOD=POST ACTION=" http://172.17.2.85:8988/JavaServlets-Servlet1-context-root/servlet1">
Please input your ID
<p><INPUT TYPE=TEXT NAME="theid"></p>
<p><INPUT TYPE=HIDDEN NAME="thesql" VALUE="select * from SER where ID = "></p>
<p><INPUT TYPE=SUBMIT VALUE=" SUBMIT "></p>
</FORM>
</BODY>
</HTML>

DB: 表名 SER ,字段为 ID,VALUE,NAME
先用 Post 方法接收参数,然后在DB搜索,最后以html格式返回。
虽然简单,学到的东西还挺多,有待继续研究:) 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值