获取浏览器的header信息

String Agent = request.getHeader("User-Agent");
StringTokenizer st = new StringTokenizer(Agent,";");
st.nextToken();
//得到用户的浏览器名
String userbrowser = st.nextToken();
//得到用户的操作系统名
String useros = st.nextToken();
-----------------
StringTokenizer:字符串分隔解析类型
属于:java.util包。

1、构造函数。


1. StringTokenizer(String str) :构造一个用来解析str的StringTokenizer对象。java默认的分隔符是“空格”、“制表符(‘\t’)”、“换行符(‘\n’)”、“回车符(‘\r’)”。
2. StringTokenizer(String str, String delim) :构造一个用来解析str的StringTokenizer对象,并提供一个指定的分隔符。
3. StringTokenizer(String str, String delim, boolean returnDelims) :构造一个用来解析str的StringTokenizer对象,并提供一个指定的分隔符,同时,指定是否返回分隔符。


2、方法。
说明:
1. 所有方法均为public;
2. 书写格式:[修饰符] <返回类型> <方法名([参数列表])>
如:
static int parseInt(String s) 表示:此方法(parseInt)为类方法(static),返回类型为(int),方法所需参数为String类型。


1. int countTokens() :返回nextToken方法被调用的次数。如果采用构造函数1和2,返回的就是分隔符数量(例2)。
2. boolean hasMoreTokens() :返回是否还有分隔符。
3. boolean hasMoreElements() :结果同2。
4. String nextToken() :返回从当前位置到下一个分隔符的字符串。
5. Object nextElement() :结果同4。
6. String nextToken(String delim) :与4类似,以指定的分隔符返回结果。
--------------------------------------

取得本机的信息也可以这样:

操作系统信息
System.getProperty("os.name"); //win2003竟然是win XP
System.getProperty("os.version");
System.getProperty("os.arch");
瀏覽器:
request.getHeader("User-Agent")

再送个红包
request.getHeader(“User-agent”)返回客户端浏览器的版本号、类型

getHeader(String name):获得http协议定义的传送文件头信息,

request. getMethod():获得客户端向服务器端传送数据的方法有GET、POST、PUT等类型

request. getRequestURI():获得发出请求字符串的客户端地址

request. getServletPath():获得客户端所请求的脚本文件的文件路径

request. getServerName():获得服务器的名字

request.getServerPort():获得服务器的端口号

request.getRemoteAddr():获得客户端的IP地址

request.getRemoteHost():获得客户端电脑的名字,若失败,则返回客户端电脑的IP地址

request.getProtocol():

request.getHeaderNames():返回所有request header的名字,结果集是一个Enumeration(枚举)类的实例

request.getHeaders(String name):返回指定名字的request header的所有值,结果集是一个Enumeration(枚举)类的实例
---------------------------------------------
Request Header简介
  当一个客户端(通常是浏览器)向Web服务器发送一个请求是,它要发送一个请求的命令行,一般是GET或POST命令,当发送POST命令时,它还必须向服务器发送一个叫“Content-Length”的请求头(Request Header) 用以指明请求数据的长度,除了Content-Length之外,它还可以向服务器发送其它一些Headers,如:
  Accept 浏览器可接受的MIME类型
  Accept-Charset 浏览器支持的字符编码
  Accept-Encoding 浏览器知道如何解码的数据编码类型(如 gzip)。Servlets 可以预先检查浏览器是否支持gzip并可以对支持gzip的浏览器返回gzipped的Html页面,并设置Content-Encoding回应头(response header)来指出发送的内容是已经gzipped的。在大多数情况下,这样做可以加快网页下载的速度。
  Accept-Language 浏览器指定的语言,当Server支持多语种时起作用。
  Authorization 认证信息,一般是对服务器发出的WWW-Authenticate头的回应。
  Connection 是否使用持续连接。假如servlet发现这个字段的值是Keep-Alive,或者由发出请求的命令行发现浏览器支持 HTTP 1.1 (持续连接是它的默认选项),使用持续连接可以使保护很多小文件的页面的下载时间减少。
  Content-Length (使用POST方法提交时,传递数据的字节数)
  Cookie (很重要的一个Header,用来进行和Cookie有关的操作,具体的信息将在后面的教程中介绍)
  Host (主机和端口)
  If-Modified-Since (只返回比指定日期新的文档,假如没有,将会反回304 "Not Modified")
  Referer (URL)
  User-Agent (客户端的类型,一般用来区分不同的浏览器)
  假如你想更多的了解Request Header的内容,你可以访问W3C的网站。
  在Servlet中读取Request Header的内容
  在Servlet中读取Request Header的值是很简单的,只要调用HttpServletRequest的getHeader方法就可以了,当你指定要返回的Header的名称,该方法就会返回String类型的Header的内容,假如指定的Header不存在,就返回null。调用getHeaderNames可以返回包含所有Header名字的Enumeration.
  读取所有Request Header值的Servlet程序
  下面是Tomcat中所带的Servlet例子中关于Request Header的例子,下载该程序。
  
import Java.io.*;
  import java.util.*;
  import javax.servlet.*;
  import javax.servlet.http.*;
  public class RequestHeaderExample extends HttpServlet {
  public void doGet(HttpServletRequest request, HttpServletResponse response)
  throws IOException, ServletException
  {
  response.setContentType("text/html");
  PrintWriter out = response.getWriter();
  Enumeration e = request.getHeaderNames();
  while (e.hasMoreElements()) {
  String name = (String)e.nextElement();
  String value = request.getHeader(name);
  out.println(name + " = " + value);
  }
  }
  }


获取header的全部信息,采用了枚举型,具体方式如下(固定代码)
StringBuffer sb = new StringBuffer();
		Enumeration en = request.getHeaderNames();
		while (en.hasMoreElements()) {
			String name = (String) en.nextElement();
			String value = request.getHeader(name);
			sb.append(name + "=" + value + "\r\n");
		}
		log.setFullhead(sb.toString());

你可能感兴趣的:(tomcat,浏览器,servlet,OS,XP)