0

私はバディプレスを使用してワードプレスサイトに取り組んでいます。そこで、wp_users というデータベースを使用してメンバーを表示および検索できるページを作成しています。wpページに追加するときにphpとして持っている場合、これは正常に機能しますが、送信をクリックすると404エラーが発生します。

これはコードです:

    <!DOCTYPE  HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"  "http://www.w3.org/TR/html4/loose.dtd">
<html>
  <head>
    <meta  http-equiv="Content-Type" content="text/html;  charset=utf-8">
    <title>Search  Contacts</title>
  <style type="text/css">
  #spacer {
    border-top-width: 1px;
    border-right-width: 1px;
    border-bottom-width: 1px;
    border-left-width: 1px;
    border-top-style: solid;
}
  </style>
  </head>
  <p><body>
    <p>&nbsp;</p>
    <form  method="post" action=""  id="searchform">
      <p>
        <input name="name"  type="text">
        <input  type="submit" name="submit" value="Søk">
      </p>
      <p>Tips: du kan søke etter adresse, navn og e-post.</p>
    </form>

  <table width="600">
            <tr>
              <th width="200" height="50">Navn</th>
                <th width="200">&nbsp;</th>
              <th width="200">E-post adresse</th>
            </tr>  
<?php
/* Change next two lines  if using online*/
$db="skynnaks_skyn";
$link = mysql_connect('localhost', 'skynnaks_skyn', '*password*');

if (! $link) die(mysql_error());
mysql_select_db($db , $link) or die("Couldn't open $db: ".mysql_error());
$result = mysql_query( "SELECT * FROM wp_users" )
          or die("SELECT Error: ".mysql_error());
$num_rows = mysql_num_rows($result);

if ($result) {

while ($row = mysql_fetch_array($result)) { 
$_SESSION['id']=$row['id'];
#echo "<tr><a href='#'>".$row['display_name']."</a>";
echo "<td><a href="."/members/".$row['user_nicename']."/profile/>".$row['display_name']."</a></td>";
#echo "<a href=" '.$row['id'].'>Bruker: ".$row['user_url']."</a>";
echo "<td><a href=".$row['user_url'].">".$row['user_url']."</a></td>";
echo "<td><a href=".'mailto:'.$row['user_email'].">".$row['user_email']."</a></td></tr>";
}
}


?>
</table>
    <div id="spacer">
     <?php
  if(isset($_POST['submit'])){
  if(preg_match("/^[  a-zA-Z]+/", $_POST['name'])){
  $name=$_POST['name'];
  //connect  to the database
  $db=mysql_connect  ("localhost", "skynnaks_skyn",  "*password*") or die ('I cannot connect to the database  because: ' . mysql_error());
  //-select  the database to use
  $mydb=mysql_select_db("skynnaks_skyn");
  //-query  the database table
  $sql="SELECT  ID, user_login, user_nicename FROM wp_users WHERE user_login LIKE '%" . $name .  "%' OR user_nicename LIKE '%" . $name ."%'";
  //-run  the query against the mysql query function
  $result=mysql_query($sql);
  //-create  while loop and loop through result set
  while($row=mysql_fetch_array($result)){
          $loginName  =$row['user_login'];
          $niceName=$row['user_nicename'];
          $ID=$row['ID'];
  //-display the result of the array

  echo "<ul>\n";
  echo "<li>" . "<a href="."/members/".$loginName."/profile/>".$niceName."</a>" ;
  echo "</ul>";
  }
  }
  else{
  echo  "<p>Please enter a search query</p>";
  }
  }
?>
  </div>
    <p>&nbsp;</p>


  </body>
</html>
</p>

PS: buddypress プラグインが原因で、デフォルトのパーマリンクを使用できません。また、buddypress にはメンバー検索が付属していることは知っていますが、ノルウェー語の言語パックをインストールしましたが、budypress のメンバー検索では機能しません。

助けてくれてありがとう :)

4

1 に答える 1