像鸟儿一样飞翔

 
 

常用链接

  • 我的随笔
  • 我的评论
  • 我的参与
  • 最新评论

留言簿(3)

  • 给我留言
  • 查看公开留言
  • 查看私人留言

随笔分类

  • java技术(2) (rss)
  • web应用 (rss)
  • 数据库技术(2) (rss)
  • 杂谈(3) (rss)
  • 随想 (rss)

随笔档案

  • 2007年1月 (9)
  • 2006年12月 (1)
  • 2006年11月 (1)

文章分类

  • java技术(6) (rss)
  • 娱乐 (rss)
  • 数据库 (rss)
  • 杂谈(1) (rss)
  • 跨服征途(1) (rss)

文章档案

  • 2007年1月 (1)
  • 2006年12月 (4)
  • 2006年11月 (3)

搜索

  •  

最新评论

  • 1. re: 将excel嵌入html[未登录]
  • dsfsgags
  • --yang
  • 2. re: 关于session失效的问题(内网IP与外网IP)
  • 评论内容较长,点击标题查看
  • --邰振南
  • 3. re: 关于在JSP页面上同时显示简体和繁体的问题(字符编码)
  • 不用这么麻烦的, 在server.xml 中 加个URIEncoding="UTF-8" 就行了
  • --繁体字
  • 4. re: 关于session失效的问题(内网IP与外网IP)
  • 大哥 问题解决了吗 共享一下啊 我实在很郁闷 你说的方法不行啊
  • --ss
  • 5. re: 关于在JSP页面上同时显示简体和繁体的问题(字符编码)
  • hao
  • --繁体

阅读排行榜

  • 1. 简单的FTP客户端 sun.net.ftp.FtpClient(转自完美世界博客)(3027)
  • 2. SQL实现排序后分页查询功能(oracle)(2519)
  • 3. jsp中关于OWC的使用(转)(1625)
  • 4. oracle外部表的使用(1165)
  • 5. JBoss 中运行servlet 的helloworld程序(转)(854)

评论排行榜

  • 1. SQL实现排序后分页查询功能(oracle)(1)
  • 2. 简单的FTP客户端 sun.net.ftp.FtpClient(转自完美世界博客)(0)
  • 3. Get与post区别(0)
  • 4. jsp中关于OWC的使用(转)(0)
  • 5. 关于get方法和post方法(一)(0)

Powered by: 博客园
模板提供:沪江博客
BlogJava | 首页 | 发新随笔 | 发新文章 | 联系 | 聚合 | 管理

2007年1月12日

JBoss 中运行servlet 的helloworld程序(转)

一..在server/default/deploy下创建test.war文件夹

  在test.war 下建WEB-INF文件夹

  在WEB-INF下建classes文件夹和web.xml

二、运行
在C:\jboss-3.2.1_tomcat-4.1.24\bin下点击run.bat运行。
测试方法如下:
http://localhost:8080/jmx-console

看到jmx agent view
表示成功
三.servlet的测试

(1)测试程序:helloworld.java
import java.io.*; 
import javax.servlet.*; 
import javax.servlet.http.*; 
public class helloworld extends HttpServlet 
{ 
public void doGet(HttpServletRequest request,HttpServletResponse response)throws IOException,ServletException
{ 

response.setContentType("text/html"); 
PrintWriter out = response.getWriter(); 
out.println("<html><head><title>"); 
out.println("This is my first Servlet"); 
out.println("</title></head><body>"); 
out.println("<h1>Hello,World!</h1>"); 
out.println("</body></html>"); 

} 
} 
编译
javac helloworld.java
java helloworld
将生成的helloworld.class文件放在classes目录下。
(2)
配置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>
<servlet> 
<servlet-name>helloworld</servlet-name> 
<servlet-class>helloworld</servlet-class> 
</servlet> 
<servlet-mapping> 
<servlet-name>helloworld</servlet-name> 
<url-pattern>/helloworld</url-pattern> 
</servlet-mapping> 
</web-app>

(3) 通过调用http://localhost:8080/test/helloworld就可以看到hello world的输出!


posted @ 2007-01-19 12:24 依茗 阅读(854) | 评论 (0) | 编辑 收藏
 
SQL实现排序后分页查询功能(oracle)
在网页上显示大量数据的时候,很多时候是要求按一定的顺序分页来显示.大家可能都知道用oracle中的rownum可以实现分页查询,比如:
select * from tablename where rownum<=10.

 但是如果要排序的话,如下的语句:
select * from tablename where rownum<=10 order by name.
却不能达到我们想要的效果,这个语句执行结果是取了10条数据,然后排序.而不是先排序再取前10条.这样就需要我们加入子查询:
select * from (select * from tablename order by name) where rownum<10

另外rownum的使用是不允许我们用">"的,如果我要显示第二页,即10-20条数据,不能用
select * from (select * from tablename order by name) where  rownum>10 and rownum<20
或
select * from (select * from tablename order by name) where  rownum between 10 and 20

这样的话我们只能另想办法解决,解决方法如下:
select * from(
select rownum rowno,t.* from
 (select *
 from tablename
 order by name) t
where rownum<6)where rowno>2;

但是这样的话也会影响到速度,各位如果有好的方法可以一起探讨下.
posted @ 2007-01-17 17:33 依茗 阅读(2519) | 评论 (1) | 编辑 收藏
 
简单的FTP客户端 sun.net.ftp.FtpClient(转自完美世界博客)

某些数据交换,我们需要通过ftp来完成。

sun.net.ftp.FtpClient 可以帮助我们进行一些简单的ftp客户端功能:下载、上传文件。

但如遇到创建目录之类的就无能为力了,我们只好利用第三方源码,比如 com.enterprisedt.net.ftp.FTPClient

下面写一些sun.net.ftp.FtpClient 的使用方法。

1、引入包

import java.io.DataInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.FileInputStream;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import sun.net.*;
import sun.net.ftp.FtpClient;

2、我们建一个叫做FtpUtil的class

   /**
    * connectServer
    * 连接ftp服务器
    * @throws java.io.IOException
    * @param path 文件夹,空代表根目录
    * @param password 密码
    * @param user   登陆用户
    * @param server 服务器地址
    */

  public void connectServer(String server, String user, String password,  String path)
  throws IOException 
  {
     // server:FTP服务器的IP地址;user:登录FTP服务器的用户名
     // password:登录FTP服务器的用户名的口令;path:FTP服务器上的路径
     ftpClient = new FtpClient();
     ftpClient.openServer(server);
     ftpClient.login(user, password);
     //path是ftp服务下主目录的子目录
     if (path.length() != 0)  ftpClient.cd(path);
     //用2进制上传、下载
     ftpClient.binary();     
 }
 
 /**
    * upload
    * 上传文件
    * @throws java.lang.Exception
    * @return -1 文件不存在
    *          -2 文件内容为空 
    *          >0 成功上传,返回文件的大小
    * @param newname 上传后的新文件名
    * @param filename 上传的文件
    */

 public long upload(String filename,String newname) throws Exception 
 {
     long result = 0;
     TelnetOutputStream os = null;
     FileInputStream is = null;
     try {         
         java.io.File file_in = new java.io.File(filename);
         if (!file_in.exists()) return -1;
         if (file_in.length()==0) return -2;
         os = ftpClient.put(newname);
         result = file_in.length();
         is = new FileInputStream(file_in);
         byte[] bytes = new byte[1024];
         int c;
         while ((c = is.read(bytes)) != -1) {
              os.write(bytes, 0, c);
         }
     } finally {
         if (is != null) {
             is.close();
         }
         if (os != null) {
            os.close();
         }
     }
    return result;
 }
 /**
    * upload
    * @throws java.lang.Exception
    * @return 
    * @param filename
    */

 public long upload(String filename)
 throws Exception 
 {
    String newname = "";
    if (filename.indexOf("/")>-1)
    {
       newname = filename.substring(filename.lastIndexOf("/")+1);
    }else
    {
       newname = filename;
    }
    return upload(filename,newname);
 }
 
 /**
    *  download
    *  从ftp下载文件到本地
    * @throws java.lang.Exception
    * @return 
    * @param newfilename 本地生成的文件名
    * @param filename 服务器上的文件名
    */

 public long download(String filename,String newfilename) 
 throws Exception
 {  
    long result = 0;
    TelnetInputStream is = null;
    FileOutputStream os = null;
    try 
    {
       is = ftpClient.get(filename);       
       java.io.File outfile = new java.io.File(newfilename);
       os = new FileOutputStream(outfile);
       byte[] bytes = new byte[1024];
       int c;
       while ((c = is.read(bytes)) != -1) {
           os.write(bytes, 0, c);
           result = result + c;
       }
    } catch (IOException e) 
    {
       e.printStackTrace();
    }
    finally {
         if (is != null) {
             is.close();
         }
         if (os != null) {
            os.close();
         }
     }
     return result;
 }
 /**
  * 取得某个目录下的所有文件列表
  *
  */

 public List getFileList(String path)
 {
    List list = new ArrayList();
    try 
    {
       DataInputStream dis = new  DataInputStream(ftpClient.nameList(path));
       String filename = "";
       while((filename=dis.readLine())!=null)  
       {  
         list.add(filename);        
       }  
   
    } catch (Exception e) 
    {
       e.printStackTrace();
    }
    return list;
 }
 
 /**
    * closeServer
    * 断开与ftp服务器的链接
    * @throws java.io.IOException
    */

 public void closeServer()
 throws IOException 
 {   
   try 
   {
      if (ftpClient != null) 
      {
        ftpClient.closeServer();     
      }
   } catch (IOException e) {
      e.printStackTrace();
   }
 }
  
  public static void main(String [] args) throws Exception 
  {
    FtpUtil ftp = new FtpUtil();
    try {
         //连接ftp服务器
         ftp.connectServer("10.163.7.15", "cxl", "1", "info2");
         /**  上传文件到 info2 文件夹下 */
         System.out.println("filesize:"+ftp.upload("f:/download/Install.exe")+"字节");
         /** 取得info2文件夹下的所有文件列表,并下载到 E盘下 */
         List list = ftp.getFileList(".");
         for (int i=0;i<list.size();i++)
         {
            String filename = (String)list.get(i);
            System.out.println(filename);
            ftp.download(filename,"E:/"+filename);
         }
    } catch (Exception e) {
       ///
    }finally
    {
       ftp.closeServer();
    }
  }  
}
posted @ 2007-01-12 11:25 依茗 阅读(3027) | 评论 (0) | 编辑 收藏
 
Get与post区别

1、 get是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到。post是通过HTTP post机制,将表单内各个字段与其内容放置在HTML HEADER内一起传送到ACTION属性所指的URL地址。用户看不到这个过程。

2
、 对于get方式,服务器端用Request.QueryString获取变量的值,对于post方式,服务器端用Request.Form获取提交的数据。两种方式的参数都可以用Request来获得。

3
、Get 方式传输的数据量非常小,一般限制在 2 KB 左右,但是执行效率却比 Post 方法好;而 Post 方式传递的数据量相对较大,它是等待服务器来读取数据,不过也有字节限制,这是为了避免对服务器用大量数据进行恶意攻击,根据微软方面的说法,微软对用 Request.Form() 可接收的最大数据有限制,IIS 4 中为 80 KB 字节,IIS 5 中为 100 KB 字节

4、 <form method="get" action="a.asp?b=b">跟<form method="get" action="a.asp">是一样的,也就是说,action页面后边带的参数列表会被忽视;而<form method="post" action="a.asp?b=b">跟<form method="post" action="a.asp">是不一样的。
建议:除非你肯定你提交的数据可以一次性提交,否则请尽量用 Post 方法

5、get安全性非常低,post安全性较高。
   Get
方式提交数据,会带来安全问题,比如一个登陆页面,通过 Get 方式提交数据时,用户名和密码将出现在 URL 上,如果页面可以被缓存或者其他人可以访问客户这台机器,就可以从历史记录获得该用户的帐号和密码,所以表单提交建议使用 Post 方法;Post 方法提交的表单页面常见的问题是,该页面如果刷新的时候,会弹出一个对话框
建议:出于安全性考虑,建议最好使用 Post 提交数据

 

posted @ 2007-01-12 09:21 依茗 阅读(690) | 评论 (0) | 编辑 收藏