Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 926|回复: 0

关于JSP静态化与伪静态的简单做法

[复制链接]

该用户从未签到

发表于 2011-7-31 21:43:31 | 显示全部楼层 |阅读模式
由于也是刚看,也没有更深一步的了解,JSP静态化一般用在日志、新闻的创建而随之去创建的。而伪静态不知是为了加密,仍是流行

呵呵,下面我说下我的做法,很简朴。很适合新手。

首先是静态化:

private static final String CONTENT_TYPE = "text/HTML; charset=utf-8";
public static String isStatus(String picName,String jspName,HttpSession session,HttpServletRequest request, HttpServletResponse response){
   String uuid=java.util.UUID.randomUUID().toString();
   session=request.getSession();
   DAOFactory dao=DAOFactory.getInstance();
   String name = "";
   String htmlName="";
   try {
    response.setContentType(StatUtil.CONTENT_TYPE);
    String url = "";
   
    ServletContext sc =session.getServletContext();
   
    // 你要访问的jsp文件,如index.jsp
    // 则你访问这个servlet时加参数.如http://localhost/toHtml?file_name=index
    url = "/"+jspName;
    // 这是你要天生HTML的jsp文件,如
  

    name = request.getRealPath("/")+"pic-name-"+uuid+".html";
    htmlName="pic-name-"+uuid+".html";
  
    // 这是天生的html文件名,如index.htm.
    RequestDispatcher rd = sc.getRequestDispatcher(url);
    final ByteArrayOutputStream os = new ByteArrayOutputStream();
    final ServletOutputStream stream = new ServletOutputStream() {
     public void write(byte[] data, int offset, int length) {
      os.write(data, offset, length);
     }

     public void write(int b) throws IOException {
      os.write(b);
     }
    };
    final PrintWriter pw = new PrintWriter(new OutputStreamWriter(os));
    HttpServletResponse rep = new HttpServletResponseWrapper(response) {
     public ServletOutputStream getOutputStream() {
      return stream;
     }

     public PrintWriter getWriter() {
      return pw;
     }
    };
    rd.include(request, rep);
    pw.flush();
    FileOutputStream fos = new FileOutputStream(name);
    // 把jsp输出的内容写到xxx.htm
    os.writeTo(fos);
    fos.close();
  
   } catch (Exception e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
   return htmlName;
}

以上是个方法,可以摘摘剪剪的放在自己的程序里。

但是要留意,request传值,一定要放在这个上面去做,否则得话,页面里将没有内容。反正我试的结果就是这样。

下面是伪静态。这块我也是从网上摘找的工具类,试了一下,很好使,很强盛。

第一步,创建两个工具类。

代码如下,直接粘过去就可以用了。


public class Base64Coder {

private static char[] map1 = new char[64];
static {
   int i = 0;
   for (char c = 'a'; c <= 'z'; c++)
    map1[i++] = c;
   for (char c = '0'; c <= '9'; c++)
    map1[i++] = c;
   for (char c = 'A'; c <= 'Z'; c++)
    map1[i++] = c;
   map1[i++] = '+';
   map1[i++] = '/';
}

private static byte[] map2 = new byte[128];
static {
   for (int i = 0; i < map2.length; i++)
    map2 = -1;
   for (int i = 0; i < 64; i++)
    map2[map1] = (byte) i;
}

public static String encodeString(String s) {
   return new String(encode(s.getBytes()));
}

public static char[] encode(byte[] in) {
   return encode(in, in.length);
}

public static char[] encode(byte[] in, int iLen) {
   int oDataLen = (iLen * 4 + 2) / 3; // output length without padding
   int oLen = ((iLen + 2) / 3) * 4; // output length including padding
   char[] out = new char[oLen];
   int ip = 0;
   int op = 0;
   while (ip < iLen) {
    int i0 = in[ip++] & 0xff;
    int i1 = ip < iLen ? in[ip++] & 0xff : 0;
    int i2 = ip < iLen ? in[ip++] & 0xff : 0;
    int o0 = i0 >>> 2;
    int o1 = ((i0 & 3) << 4) | (i1 >>> 4);
    int o2 = ((i1 & 0xf) << 2) | (i2 >>> 6);
    int o3 = i2 & 0x3F;
    out[op++] = map1[o0];
    out[op++] = map1[o1];
    out[op] = op < oDataLen ? map1[o2] : '_';
    op++;
    out[op] = op < oDataLen ? map1[o3] : '_';
    op++;
   }
   return out;
}

public static String decodeString(String s) {
   return new String(decode(s));
}

public static byte[] decode(String s) {
   return decode(s.toCharArray());
}

public static byte[] decode(char[] in) {
   int iLen = in.length;
   if (iLen % 4 != 0)
    throw new IllegalArgumentException(
      "Length of Base64 encoded input string is not a multiple of 4.");
   while (iLen > 0 && in[iLen - 1] == '_')
    iLen--;
   int oLen = (iLen * 3) / 4;
   byte[] out = new byte[oLen];
   int ip = 0;
   int op = 0;
   while (ip < iLen) {
    int i0 = in[ip++];
    int i1 = in[ip++];
    int i2 = ip < iLen ? in[ip++] : 'A';
    int i3 = ip < iLen ? in[ip++] : 'A';
    if (i0 > 127 || i1 > 127 || i2 > 127 || i3 > 127)
     throw new IllegalArgumentException(
       "Illegal character in Base64 encoded data.");
    int b0 = map2[i0];
    int b1 = map2[i1];
    int b2 = map2[i2];
    int b3 = map2[i3];
    if (b0 < 0 || b1 < 0 || b2 < 0 || b3 < 0)
     throw new IllegalArgumentException(
       "Illegal character in Base64 encoded data.");
    int o0 = (b0 << 2) | (b1 >>> 4);
    int o1 = ((b1 & 0xf) << 4) | (b2 >>> 2);
    int o2 = ((b2 & 3) << 6) | b3;
    out[op++] = (byte) o0;
    if (op < oLen)
     out[op++] = (byte) o1;
    if (op < oLen)
     out[op++] = (byte) o2;
   }
   return out;
}

private Base64Coder() {
}

}

-----------------------------------------------------------------------------------------------

import java.util.*;
public class HtmlUtil {
protected static int JSP=20091;
protected static int ACTION=20092;
protected static int HTML=20093;
protected static int SEALED=404;
protected static String propertyName;//项目名称以及 前面得 那段文件夹路径
protected static String actionName;//action的名称
protected static String operate;//action执行的方 或则 jsp页面的名称
protected static int type;//类型
protected static HashMap<String, String> items=new HashMap<String, String>();
/**
* 把真实得url转换为html路径 (例:/Shopping/user.do?operate=doLogin&userName=xiaowu&password=19890104)
*/
public static synchronized String getHtmlUrl(String url){
   //判定类型
   type=getType(url);
   propertyName=getPropertyName(url);
   //假如是一个ACTION
   if(type==ACTION){
    actionName=getActionName(url,true);
    operate=getFunctionName(url,true);
    items=getItems(url,true);
   }
   if(type==JSP){
    actionName=getJspName(url,true);
    items=getItems(url,true);
   }

   //创建URL
   return createHtmlUrl();
}
/**
* 创建Html路径
* @return
*/
protected static String createHtmlUrl(){
   StringBuffer newUrl=new StringBuffer("");
   newUrl.append(actionName);
   newUrl.append("_");
   if(operate!=null&&!operate.equals("")){
    newUrl.append(operate);
   }
   newUrl.append("_");
   newUrl.append(type);
   newUrl.append("_");
   Set<String> keys=items.keySet();
   for (Object key : keys) {
    newUrl.append(key+"_"+items.get(key)+"_");
   }
   //对字符串进行编码
   String coding=Base64Coder.encodeString(newUrl.toString());
   if(propertyName!=null&&!propertyName.equals("")){
    return propertyName+coding+".html";
   }
   return coding+".html";
}
/**
* 把html路径转换为真实的路径
*/
public static synchronized String getRealityUrl(String url){
   //判定类型
   type=getType(url);
   if(type==JSP||type==ACTION){
    //路径为加密就直接返回
    return url;
   }
   propertyName=getPropertyName(url);
   String newUrl="";
   if(type==HTML){
    try{
     newUrl=url.substring(url.lastIndexOf("/")+1,url.length()-5);
     //对字符串进行解码
     newUrl=Base64Coder.decodeString(newUrl);
     actionName=getActionName(newUrl, false);
     operate=getFunctionName(newUrl,false);
     items=getItems(newUrl,false);
     type=getUrlType(newUrl);
    }catch(Exception ee){
     //假如是html页面强制改为jsp
     if(url.substring(url.length()-5).equalsIgnoreCase(".html")){
      //newUrl被改写过 所有要重新取得
      newUrl=url.substring(url.lastIndexOf("/")+1,url.length()-5);
      return newUrl+".jsp";
     }
     //假如URL无法通过解码那么就直接返回
     return url;
    }
   }
   return createRealityUrl();
}
// /**
// * 动态创建
// */
// public static synchronized String getHtmlUrl(String url,boolean b){
//   if(b==true){
//    if(url.indexOf("?")==-1){
//     url+="?";
//     url+="id"+System.currentTimeMillis()+"="+new Random().nextFloat();
//    }else{
//     url+="&id"+System.currentTimeMillis()+"="+new Random().nextFloat();
//    }
//   }
//   return getHtmlUrl(url);
// }
/**
* 还原真实路径
* @return
*/
protected static String createRealityUrl(){
   StringBuffer newUrl=new StringBuffer("");
   if(propertyName!=null&&!propertyName.equals("")){
    newUrl.append(propertyName);
   }
   if(actionName!=null&&!actionName.equals("")){
    if(type==ACTION){
     if(!operate.equals("")){
      newUrl.append(actionName+".do?operate="+operate);
     }else{
      newUrl.append(actionName+".do");
     }
    }else if(type==JSP){
     newUrl.append(actionName+".jsp");
    }else if(type==HTML){
     newUrl.append(actionName+".html");
    }else{
     newUrl.append(actionName);
    }
   }
   Set<String> keys=items.keySet();
   boolean isInterrogation=newUrl.toString().indexOf("?")!=-1?true:false;
   for (Object key : keys) {
    if(isInterrogation==false){
     newUrl.append("?");
     isInterrogation=true;
    }else{
     newUrl.append("&");
    }
    newUrl.append(key+"="+items.get(key));
   }
   return newUrl.toString();
}
// public static void main(String[] args) {
//   String strs[]={"/Shopping/user.do?operate=doLogin&userName=xiaowu&password=19890104",
//     "/Shopping/user.jsp?userName=xiaowu&password=19890104",
//     "user.do?operate=doLogin&userName=xiaowu&password=19890104",
//     "user.jsp?userName=xiaowu&password=19890104",
//     "/user.do?operate=doLogin&userName=xiaowu&password=19890104",
//     "/user.jsp?userName=xiaowu&password=19890104",
//     "user.do?operate=doLogin",
//     "/user.jsp",
//     "/Shopping/user.do",
//     "/Shopping/user.jsp",
//     "user.do",
//     "/user.do",
//     "user.jsp",
//     "/user.jsp",
//     "/Shopping/MyJsp.jsp"};
//   for (int i = 0; i < strs.length; i++) {
//    System.err.println("原路径"+strs);
//    String str=HtmlUtil.getHtmlUrl(strs);
//    System.err.println("加密后"+str);
//    str=HtmlUtil.getRealityUrl(str);
//    System.err.println("还原后"+str);
//    System.err.println("-----------------------------------------");
//   }
// }
/**
* 返回类型
*/
protected static int getUrlType(String url){
   if(url.indexOf("__")!=-1){
    return Integer.parseInt(getStr(url,1,"_"));
   }
   return Integer.parseInt(getStr(url,2,"_"));
}
/**
* 返回项目名称
*/
protected static String getPropertyName(String url){
   if(url.indexOf("/")==-1){
    return "";
   }
   return url.substring(0,url.lastIndexOf("/")+1);
}
/**
* 返回ACTION名称
*/
protected static String getActionName(String url,boolean b){
   if(b==false){
    return getStr(url,0,"_");
   }
   if(url.indexOf("/")==-1){
    return url.substring(0,url.indexOf("."));
   }
   return url.substring(url.lastIndexOf("/")+1,url.indexOf("."));
}
/**
* 返回JSP名称
*/
protected static String getJspName(String url,boolean b){
   if(url.indexOf("/")==-1){
    return url.substring(0,url.indexOf("."));
   }
   return url.substring(url.lastIndexOf("/")+1,url.indexOf("."));
}
/**
* 返回方法名称
*/
protected static String getFunctionName(String url,boolean b){
   if(b==false){
    if(url.indexOf("__")!=-1){
     return "";
    }
    return getStr(url,1,"_");
   }
   if(url.indexOf("?")==-1)
    return "";
   url=url.substring(url.lastIndexOf("operate=")+8,url.length());
   if(url.indexOf("&")==-1){
    return url;
   }
   return url.substring(0,url.indexOf("&"));
}

/**
*
*/
protected static String getStr(String str,int count,String condition){
   java.util.StringTokenizer tok=new StringTokenizer(str,condition);
   int index=0;
   while(tok.hasMoreElements()){
    String newStr=tok.nextElement().toString();
    if(index==count){
     return newStr;
    }
    index++;
   }
   return "";
}

/**
* 返回items
*/
protected static HashMap<String, String> getItems(String url,boolean b){
   HashMap<String, String> items=new HashMap<String, String>();
   if(b==false){
    java.util.StringTokenizer tok=new StringTokenizer(url,"_");
    int index=0;
    if(url.indexOf("__")!=-1){
     index++;
    }
    while(tok.hasMoreElements()){
     String newStr=tok.nextToken();
     if(index>=3){
      String key=newStr;
      String value=null;
      try {
       value=tok.nextToken();
      } catch (Exception e) {
       value="";
      }
      items.put(key, value);
     }
     index++;
    }
    return items;
   }
   url=url.substring(url.lastIndexOf("?")+1,url.length());
   java.util.StringTokenizer tok=new StringTokenizer(url,"&");
   while(tok.hasMoreElements()){
    String str=tok.nextToken();
    if(str.indexOf("operate=")==-1&&str.indexOf("=")!=-1){
     StringTokenizer newTok=new StringTokenizer(str,"=");
     if(newTok.hasMoreElements()){
      String key=newTok.nextToken();
      newTok.hasMoreElements();
      String value=null;
      try {
       value=newTok.nextToken();
       if(value.equals("")){
        value=null;
       }
      } catch (Exception e) {
       value=null;
      }
      if(key.equals("")){
       key=null;
      }
      items.put(key, value);
     }
    }
   }
   return items;
}
/**
* 判定类型
*/
protected static int getType(String url){
   if(url.toUpperCase().indexOf(".DO")!=-1){
    return ACTION;
   }else if(url.toUpperCase().indexOf(".JSP")!=-1){
    return JSP;
   }else if(url.toUpperCase().indexOf(".HTML")!=-1){
    return HTML;
   }else{
    return SEALED;
   }
}
}

------------------------------------------

第二步,创建一个servlet。嗯,我的程序时用status做的,只要在web.xml里面添加一个servlet标签就可以了。如下:

<servlet>
   <servlet-name>HtmlDecode</servlet-name>
   <servlet-class>
    com.clothes.util.statUtil.HtmlDecode ///////这是你的servlet的位置
   </servlet-class>
</servlet>

<servlet-mapping>
   <servlet-name>HtmlDecode</servlet-name>
   <url-pattern>*.html</url-pattern>

</servlet-mapping>

///这是让你的所有以*.html跳转都跑到这个servlet里面,当然,也可以改成别的。都可以的。只要在htmlUtil类里去修改一下就可以了。用起来很惬意的。

第三步,就是使用咯。很简朴,如下:

<A href="<%=HtmlUtil.getHtmlUrl("findProject.do?goodsid=123“)%>" >啦啦啦</a>

直接使用HtmlUtil里面的getHtmlUrl方法,他会在servlet编译的时候,将你要跳转的地址栏加密,同时在提交的时候,先跑到我们上面配置的哪个servlet里面,进行解密,然后跳转到你的.do或者其他的里面。挺好用的,不外一定要留意一点,就是那个goodsid这最好别加“_”,前面也最好别加。否则得话,就不灵了。嗯,这也是亲自经历。当然,这个传中文。。。我先试下!

嗯,不错,刚试了<a>提交和表单提交。结果是都可以的。假如用<a>提交泛起乱码的话,就用我之前发的那个转乱码的工具类转一下就好了。可以支持中文
可以了。以上就这些,但愿可以对大家有些匡助。

哎呀。。发现servlet忘了写进去了。现在加上,第二步的servlet:

import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import util.*;

public class HtmlDecode extends HttpServlet {
private static final long serialVersionUID = 1L;
public void doGet(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
   this.doPost(request, response);
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
   response.setCharacterEncoding("GBK");
   request.setCharacterEncoding("GBK");
   //掏出URL
   String url=request.getRequestURI();
   //对URL进行解码
   String newUrl=HtmlUtil.getRealityUrl(url);
   System.out.println(newUrl);
   newUrl=newUrl.replaceAll(request.getContextPath()+"/", "");
   //跳转到解码后的页面
   request.getRequestDispatcher(newUrl).forward(request, response);
}
}

OK。就是这些。
回复

使用道具 举报

  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2011-7-31 22:28:23 | 显示全部楼层
    谢谢楼主分享。
    回复 支持 反对

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-11 06:03 , Processed in 0.326312 second(s), 37 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表