2

php と mysql に問題があり、utf-8 を使用してデータベースに挿入します。最初のファイル: addsite:

<?php
include 'header.php';
if(isset($data)) {
foreach($_POST as $key => $value) {
$posts[$key] = filter($value);
}
if(isset($posts['type'])){
if($posts['url'] == "http://" || $posts['url'] == ""){
$error = "Add your page link!";
}else if($posts['title'] == ""){
$error = "Add your page title!";
}else if(!preg_match("/\bhttp\b/i", $posts['url'])){
$error = "URL must contain http://";
}else if(!preg_match('|^http(s)?://[a-z0-9-]+(.[a-z0-9-]+)*(:[0-9]+)?(/.*)?$|i',       $posts['url'])){
$error = "Please do not use special characters in the url.<";
}else{
    include "plugins/" . $posts['type'] . "/addsite.php";
}
}
?>
<div class="contentbox">
<font size="2">
<li>Pick the type of exchange you are promoting from the dropdown menu.</li>
<li>Set the amount of coins you wish to give per user complete(CPC).</li>
<li>The higher the amount of coins the higher the Links position.</li>
</div>
<div class="contentbox">
<div class="head">Add Site</div>
<div class="contentinside">
    <?php if(isset($error)) { ?>
    <div class="error">ERROR: <?php echo $error; ?></div>
    <?php }
    if(isset($success)) { ?>
    <div class="success">SUCCESS: <?php echo $success; ?></div>
    <?php }
    if(isset($warning)) { ?>
    <div class="warning">WARNING: <?php echo $warning; ?></div>
    <?php } ?>

    <form class="contentform" method="post">
        Type<br/>
        <select name="type"><?php $select = hook_filter('add_site_select', ""); echo   $select; ?></select><br/><br/>
        Link<br/>
        <input name="url" type="text" value="<?php if(isset($posts["url"])) { echo $posts["url"]; } ?>"/><br/><br/>
        Title<br/>
        <input name="title" type="text" value="<?php if(isset($posts["title"])) { echo $posts["title"]; } ?>"/><br/><br/>
        Cost Per Click<br/>
        <?php if($data->premium > 0) { ?>
        <select name="cpc"><?php for($x = 2; $x <= $site->premcpc; $x++) { if(isset($posts["cpc"]) && $posts["cpc"] == $x) { echo "<option selected>$x</option>"; } else { echo "<option>$x</option>"; } } ?></select><br/><br/>
        <?php }else{ ?>
        <select name="cpc"><?php for($x = 2; $x <= $site->cpc; $x++) { if(isset($posts["cpc"]) && $posts["cpc"] == $x) { echo "<option selected>$x</option>"; } else { echo "<option>$x</option>"; } } ?></select><br/><br/>
        <?php } ?>
        <input style="width:40%;" type="Submit"/>
    </form>
</div>
 </div>
<?php
 }
else
 {
echo "Please login to view this page!";
 }
 include 'footer.php';
  ?>    

2 番目のファイル、プラグイン addsite.php

<?php
$num1 = mysql_query("SELECT * FROM `facebook` WHERE `url`='{$posts['url']}'");
$num = mysql_num_rows($num1);
if($num > 0){
$error = "Page already added!";
 }else if(!strstr($posts['url'], 'facebook.com')) {
$error = "Incorrect URL! You must include 'facebook.com'";
}else{
mysql_query($qry);
  mysql_query("INSERT INTO `facebook` (user, url, title, cpc) VALUES('{$data->id}', '{$posts['url']}', '{$posts['title']}', '{$posts['cpc']}') ");
$success = "Page added successfully!";
}
?>

フォームにアラビア語を書いて送信すると、次のような未知の言語でデータベースに移動しました:

オスラッシュ;£Ø³Ù

4

3 に答える 3

0

次のことを試してください。

  1. UTF-8メタタグを追加します。 <meta http-equiv="Content-type" value="text/html; charset=UTF-8" />
  2. UTF-8ヘッダーを追加: header('Content-Type: text/html; charset=utf-8');適切なマークアップがないためにタグが無視される場合
  3. スクリプトがUTF-8でエンコードされていることを確認してください(そのためにはNotepad ++を使用してください)
  4. set names 'utf8'挿入する前にクエリを実行する
于 2013-02-07T15:29:50.560 に答える
0

これを簡単にするために役立つことが 2 つあります。まず、データベースが UTF-8 形式であることを忘れないでください。次に、ページで UTF-8 コンテンツ タイプを送信するようにしてください。

MySQL の場合、データベースが既に作成されている場合は、次のようにします。

ALTER DATABASE database_name CHARACTER SET utf8 DEFAULT CHARACTER SET utf8
    COLLATE utf8_general_ci DEFAULT COLLATE utf8_general_ci;

テーブルについては、次のように変更します。

ALTER TABLE table_name DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

次に、適切なコンテンツ タイプをドキュメントと共に送信します。次の HTML タグを使用します。

<meta http-equiv="Content-type" value="text/html; charset=UTF-8" />
于 2013-02-07T15:24:01.520 に答える
0

ギリシャ文字でも同様の問題がありました。データベースではなじみがないように見えるかもしれませんが、それらは正しかったのです。

PHP で値を読み戻して、エコーを実行してみてください。正しく保管されているかどうかが表示されます。

于 2013-02-07T15:12:20.220 に答える