0
<?php
# session

session_start();

# check that session is set and is valid

if(!isset($_SESSION['login']))
   { header('Location: login.php');
}
?>
<body>
<div class="maincontainer">
  <div class="keywordhead">
    <div align="center"><img src="Images/keyword_title.png" width="243" height="56" /></div>
  </div>
  <div class="results">
  <p>
    <?php

      $kword = $_POST["kword"];

      function boldText($text, $kword) {
    return str_replace($kword, "<strong>$kword</strong>", $text);
}
      $testin1 = substr($kword,0,1);
if($testin1 == "") {
print "<strong>No Keyword or a Keyphrase Entered, Please return to the '<a href='keyword_search.php'>Keyword Search Page</a>'</strong>";
}
else {
   // Connects to your Database 
 mysql_connect("localhost", "root") or die(mysql_error()); 
 mysql_select_db("test") or die(mysql_error()); 
}
 mysql_real_escape_string($kword); 
 $data = mysql_query("select company_name, section_name, question, answer from company, rfp, section, question_keywords
where company.company_id = rfp.company_id
and rfp.rfp_id = question_keywords.rfp_id
and question_keywords.section_id = section.section_id
and keywords like '%$kword%';") 
 or die(mysql_error()); 

  echo "<table border=0 cellpadding=10>";
echo "<tr align = center bgcolor=white>
<td><b>Company Name</b></td><td><b>Section</b></td><td><b>Question</b></td><td><b>Answer</b></td>" ; 
 while($info = mysql_fetch_array( $data )) 
 { 

 echo "<tr>"; 
 echo "<td width = 130px>".boldText($info['company_name'], $kword) . "</td> ";
 echo "<td width = 60px>".boldText($info['section_name'], $kword) . " </td>"; 
 echo "<td width = 300px>".boldText($info['question'], $kword) . " </td>";
 echo "<td width = 600px>".boldText($info['answer'], $kword) . " </td></tr>"; 
 } 
 echo "</table>"; 
 ?>

  </p>
  </div>
  <div class="footer"><a href="logout.php"><br />
  Logout</a> | <a href="index.php">Index</a>  |  <a href="keyword_search.php">Back</a></div>
</div>
</body>
</html>

私はPHPに比較的慣れていないので、特定の機能が可能かどうか知りたいと思いました。検索というキーワードがあり、結果ページのコードは上にあります。$kword変数がページに表示されるところはどこでも太字にしたいと思います。これは可能ですか?

ありがとう

4

2 に答える 2

1

そのための関数を作成し、変数をエコーする前にそれを呼び出すことができます。

代わりに:$info['question']使用boldText($info['question'], $kword)

function boldText($text, $keyword) {
    return str_ireplace($keyword, "<strong>$keyword</strong>", $text);
}

補足として、SQLクエリで使用する前にmysql_real_escape_string()$kwordでエスケープすることを忘れないでください。また、mysql拡張は強く推奨されていないため、 MySQLiまたはPDOの使用を検討してください。

于 2012-09-11T11:26:51.583 に答える
0

各Printステートメントでこのようなものを使用できますか?

str_replace($kword, "<b>$kword</b>", $info[...])

(またはCSS(必要に応じて<span style ='font-weight:bold'> ... </ span>など)。

于 2012-09-11T11:30:13.393 に答える