簡體   English   中英

Java網絡后請求

[英]Java Networking Post Resquest

package loginphp;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;

public class Loginphp {

    public static void main(String[] args) throws MalformedURLException, IOException {
        String url = "http://localhost/login/login.php";
        String Parameters = "username=admin&password=admin";
        byte[] postdata = Parameters.getBytes("UTF-8");
        String useragent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:59.0) Gecko/20100101 Firefox/59.0";
        URL urlLink = new URL(url);

        HttpURLConnection urlConn = (HttpURLConnection) urlLink.openConnection();
        urlConn.setRequestMethod("POST");
        urlConn.setRequestProperty("User-Agent", useragent);
       urlConn.setRequestProperty("Content-Length", String.valueOf(postdata.length));
        urlConn.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
        urlConn.setInstanceFollowRedirects(true);
        urlConn.setDoOutput(true);
        urlConn.getOutputStream().write(postdata);

        System.out.println("Connecting to " + url);
        System.out.println("Response " + urlConn.getResponseMessage());
        System.out.println("Code " + urlConn.getResponseCode());

        InputStream is = urlConn.getInputStream();
        InputStreamReader isr = new InputStreamReader(is);
        BufferedReader bis = new BufferedReader(isr);

        String output;

        while ((output = bis.readLine()) != null) {

            System.out.println(" " + output);
        }

    }

}

正在向以下代碼發送發布請求,但登錄后未將其重定向到歡迎頁面,不確定其是否均勻登錄。得到的結果與登錄頁面的代碼相同。 可能是什么問題呢 ? 我的主要目標是登錄並重定向到welcome.php。 該腳本可以在瀏覽器中完美運行。 能夠記錄,重定向到歡迎頁面並注銷。

<?php
   include("config.php");
   session_start();
   $error = "";
   if($_SERVER["REQUEST_METHOD"] == "POST") {
      // username and password sent from form 

      $myusername = mysqli_real_escape_string($db,$_POST['username']);
      $mypassword = mysqli_real_escape_string($db,$_POST['password']); 

      $sql = "SELECT id FROM admin WHERE username = '$myusername' and passcode = '$mypassword'";
      $result = mysqli_query($db,$sql);
      $row = mysqli_fetch_array($result,MYSQLI_ASSOC);
      $active = $row['active'];

      $count = mysqli_num_rows($result);

      // If result matched $myusername and $mypassword, table row must be 1 row

      if($count == 1) {
        // session_register("myusername");
         $_SESSION['login_user'] = $myusername;

         header("location: welcome.php");
      }else {
         $error = "Your Login Name or Password is invalid";
      }
   }
?>
<html>

   <head>
      <title>Login Page</title>

      <style type = "text/css">
         body {
            font-family:Arial, Helvetica, sans-serif;
            font-size:14px;
         }

         label {
            font-weight:bold;
            width:100px;
            font-size:14px;
         }

         .box {
            border:#666666 solid 1px;
         }
      </style>

   </head>

   <body bgcolor = "#FFFFFF">

      <div align = "center">
         <div style = "width:300px; border: solid 1px #333333; " align = "left">
            <div style = "background-color:#333333; color:#FFFFFF; padding:3px;"><b>Login</b></div>

            <div style = "margin:30px">

               <form action = "" method = "post">
                  <label>UserName  :</label><input type = "text" name = "username" class = "box"/><br /><br />
                  <label>Password  :</label><input type = "password" name = "password" class = "box" /><br/><br />
                  <input type = "submit" value = " Submit "/><br />
               </form>

               <div style = "font-size:11px; color:#cc0000; margin-top:10px"><?php echo $error; ?></div>

            </div>

         </div>

      </div>

   </body>
</html>

簡短的答案是您應該使用303重定向

header("HTTP/1.1 303 See Other");
header("location: welcome.php");

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM