[英]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.