java 传入用户名和密码并自动提交表单实现登录到其他系统

不用单点登录,模拟远程项目的登录页面表单,在访问这个页面的时候自动提交表单到此项目的登录action,就可以实现登录到其他系统。

ssh框架项目

1.以下是本地系统的action代码:

 1 import java.io.IOException;
 2 import java.util.List;
 3 import java.io.BufferedReader;
 4 import java.io.IOException;
 5 import java.io.InputStreamReader;
 6 import java.io.PrintWriter;
 7 import java.net.URL;
 8 import java.net.URLConnection;
 9
10 public class myLoginAction {
11
12     /**
13      * 查询是否用户已注册
14      * @return
15      * @throws Exception
16      */
17     public void checkUser() throws Exception{
18         Loginer loginer = (Loginer) request.getSession()
19         .getAttribute("loginer");
20
21         String url = "http://www.youtest.com/login.php"; //远程系统登录action地址
22         String param = "username=Tom&password=123456"; //参数
23         String temp = "alert(‘用户名或密码错误‘);";   //返回的信息,此处是错误信息,用于比较。   视情况而定
24         boolean result =false ;
25         //验证数据是否能登录
26         result = sendPost(url, param, temp);
27         if(result){
28             return "login";
29         }else{
30             return "register";
31         }
32         }
33
34     //访问远程登录action并获取返回的信息
35     public static boolean sendPost(String url, String param, String temp) {
36             PrintWriter out = null;
37             BufferedReader in = null;
38             boolean result = true;
39             try {
40                 URL realUrl = new URL(url);
41                     // 打开和URL之间的连接
42                    URLConnection conn = realUrl.openConnection();
43                     // 设置通用的请求属性
44                     conn.setRequestProperty("accept", "*/*");
45                     conn.setRequestProperty("connection", "Keep-Alive");
46                     conn.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
47                     // 发送POST请求必须设置如下两行
48                     conn.setDoOutput(true);
49                     conn.setDoInput(true);
50                     // 获取URLConnection对象对应的输出流
51                     out = new PrintWriter(conn.getOutputStream());
52                     // 发送请求参数
53                     out.print(param);
54                     // flush输出流的缓冲
55                     out.flush();
56                     // 定义BufferedReader输入流来读取URL的响应
57                     in = new BufferedReader(new InputStreamReader(conn.getInputStream(),"UTF-8"));
58                     String line;
59                     while ((line = in.readLine()) != null) {
60                         if(temp.equals((line.trim()))) {
61                             System.out.println("错误的line:"+line);
62                             result = false;
63                         }
64                     }
65             } catch (Exception e) {
66                 result = false;
67                 logger.error("发送 POST 请求出现异常!"+e);
68                     System.out.println("发送 POST 请求出现异常!"+e);
69                     e.printStackTrace();
70             }finally{
71                     try{
72                         if(out!=null){
73                                 out.close();
74                         }
75                         if(in!=null){
76                                 in.close();
77                         }
78                     }catch(IOException ex){
79                         logger.error(ex);
80                         ex.printStackTrace();
81                     }
82             }
83             return result;
84         }
85 }

2.模拟的登录页面:

 1 <html>
 2 <head></head>
 3 <body>
 4        <script type="text/javascript">
 5          var iframe = document.createElement("iframe");
 6          iframe.src = "http://www.youtest.com/login.php?UNAME=<%=userName%>&UPWD=<%=pwd%>";
 7          iframe.style.display="none";
 8
 9          var sta="false;"
10          if (iframe.attachEvent){
11              iframe.attachEvent("onload", function(){
12                  window.location.href="http://www.youtest.com/index.html";
13              });
14          } else {
15              iframe.onload = function(){
16                  window.location.href="http://www.youtest.com/index.html";
17              };
18          }
19          document.body.appendChild(iframe);
20  </script>
21    </body>
22 </html>
时间: 2024-10-10 17:24:17

java 传入用户名和密码并自动提交表单实现登录到其他系统的相关文章

fusioncharts批量导出图片之后自动提交表单

最近一个项目  一个页面有多个fusioncharts,需要将他们一次性导出之后再利用图片做一下操作,制作一个可以客户下载的质检简报. 对客户效果来说,我只需要点击一个按钮就能生成简报并且下载,对开发人员来说就需要,先将图片导出(当然不能挨个导出,要同时执行导出,因为fusioncharts导出太慢了),要确认全部导出了才能提交表单,要不然提交表单之后,图片没有生成出来必然产生异常.下面我们来看一下实现 首先我给每一个fusionchartschart指定一个有规律的id,作用有两个: 一个是导

ssi-uploader上传图片插件,点击选择文件按钮自动提交表单解决办法

先介绍一下这款插件,然后再谈使用中可能遇到的问题 ssi-uploader是一个JQuery的图片上传插件,界面比较美观 github地址:https://github.com/ssbeefeater/ssi-uploader 演示地址:http://ssbeefeater.github.io/#ssi-uploader/examples 使用文档:http://ssbeefeater.github.io/#ssi-uploader/documentation 这里就不说明怎么使用了,githu

文件上传控件值发生变化后自动提交表单

当文件上传控件发生变化后自动提交表单,首先在页面加载完成后注册change事件,然后检测到值得变化后提交上传代码,代码备忘. <!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <script> window.

CI 自动提交表单

//coontrol $this->load->view ( '/' . $this->index_lang ['FOLDER'] . '/eprepag_form.php', $params); //view //eprepag_form.php <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-

按钮特效-Enter键自动提交表单

—————————————————————— <script type="text/javascript">                        //当用户按下键时            function formKeyPress(event){                if(event.keyCode == 13){            //判断是否按的是Enter键                    document.forms[0].submit

去掉chrome记住密码后自动填充表单的黄色背景

chrome 表单自动填充后,input文本框的背景会变成黄色的,通过审查元素可以看到这是由于chrome会默认给自动填充的input表单加上input:-webkit-autofill私有属性,然后对其赋予以下样式: input : -webkit-autofill { background-color : #FAFFBD ; background-image : none ; color : #000 ; } 在有些情况下,这个黄色的背景会影响到我们界面的效果,尤其是在我们给input文本框

回车自动提交表单

我们有时候希望回车键敲在文本框(input element)里来提交表单(form),但有时候又不希望如此.比如搜索行为,希望输入完关键词之后直接按回车键立即提交表单,而有些复杂表单,可能要避免回车键误操作在未完成表单填写的时候就触发了表单提交. 要控制这些行为,不需要借助JS,浏览器已经帮我们做了这些处理,这里总结几条规则: 如果表单里有一个type=”submit”的按钮,回车键生效.如果表单里只有一个type=”text”的input,不管按钮是什么type,回车键生效.如果按钮不是用in

&lt;button&gt;会自动提交表单吗?

点击button以后,表单先由ajax提交,然后无论后台返回什么结果,页面都会跳转到表单action属性指定的路劲,也就是login.html使用的是html.jquery.javascript,后台是spring mvc 代码如下: html表单: XML/HTML code ? 1 2 3 4 5 6 7 8 9 <form action="login.html" method="post" id="loginForm">    

javascripts 实习自动提交表单 onsubmit

html: <form id="formwb" onsubmit="return setPassword();"> <script> document.forms[0].onsubmit(); function setPassword() { //rfb.sendPassword($D('password_input').value); rfb.sendPassword("passw0rd"); return false;