這篇太優了,怕以後不見了,貼上來
從 http://rickykwan.iworkshop.com.hk/2010/03/656.html 這裡轉貼

用PHP的ob_start();控制您的瀏覽器cache!

Output Control 函數可以讓你自由控制腳本中數據的輸出。它非常地有用,特別是對于:當你想在數據已經輸出后,再輸出文件頭的情況。輸出控制函數不對使用 header() 或 setcookie(), 發送的文件頭信息產生影響,只對那些類似于 echo() 和 PHP 代碼的數據塊有作用。

我們先舉一個簡單的例子,讓大家對Output Control有一個大致的印象:
Example 1.

<?php
ob_start(); //打開緩沖區
echo \"Hellon\"; //輸出
header("location:index.php"); //把瀏覽器重定向到index.php
ob_end_flush();//輸出全部內容到瀏覽器
?>

所有對 header()函數有了解的人都知道,這個函數會發送一段文件頭給瀏覽器,但是如果在使用這個函數之前已經有了任何輸出(包括空輸出,比如空格,回車和 換行)就會提示出錯。如果我們去掉第一行的ob_start(),再執行此程序,我們會發現得到了一條錯誤提示:"Header had all ready send by"!但是加上ob_start,就不會提示出錯,原因是當打開了緩沖區,echo后面的字符不會輸出到瀏覽器,而是保留在服務器,直到你使用 flush或者ob_end_flush才會輸出,所以并不會有任何文件頭輸出的錯誤!


一、 相關函數簡介:
1、 Flush:刷新緩沖區的內容,輸出。
函數格式:flush()
說明:這個函數經常使用,效率很高。

2、ob_start :打開輸出緩沖區
函數格式:void ob_start(void)
說明:當緩沖區激活時,所有來自PHP程序的非文件頭信息均不會發送,而是保存在內部緩沖區。為了輸出緩沖區的內容,可以使用ob_end_flush()或flush()輸出緩沖區的內容。

3 、ob_get_contents :返回內部緩沖區的內容。
使用方法:string ob_get_contents(void)
說明:這個函數會返回當前緩沖區中的內容,如果輸出緩沖區沒有激活,則返回 FALSE 。

4、ob_get_length:返回內部緩沖區的長度。
使用方法:int ob_get_length(void)
說明:這個函數會返回當前緩沖區中的長度;和ob_get_contents一樣,如果輸出緩沖區沒有激活。則返回 FALSE。

5、ob_end_flush :發送內部緩沖區的內容到瀏覽器,并且關閉輸出緩沖區。
使用方法:void ob_end_flush(void)
說明:這個函數發送輸出緩沖區的內容(如果有的話)。

6、ob_end_clean:刪除內部緩沖區的內容,并且關閉內部緩沖區
使用方法:void ob_end_clean(void)
說明:這個函數不會輸出內部緩沖區的內容而是把它刪除!

7、ob_implicit_flush:打開或關閉絕對刷新
使用方法:void ob_implicit_flush ([int flag])
說明:使用過Perl的人都知道$|=x的意義,這個字符串可以打開/關閉緩沖區,而 ob_implicit_flush函數也和那個一樣,默認為關閉緩沖區,打開絕對輸出后,每個腳本輸出都直接發送到瀏覽器,不再需要調用 flush()

二、深入了解:

1. 關于Flush函數:
這個函數在PHP3中就出現了,是一個效率很高的函數,他有一個非常有用的功能就是刷新browser的cache.我們舉一個運行效果非常明顯的例子來說明flush.
Example 2.

<?php
for($i = 1; $i <= 300; $i++ ) print(" ");
// 這一句話非常關鍵,cache的結構使得它的內容只有達到一定的大小才能從瀏覽器里輸出
// 換言之,如果cache的內容不達到一定的大小,它是不會在程序執行完畢前輸出的。經
// 過測試,我發現這個大小的底限是256個字符長。這意味著cache以后接收的內容都會
// 源源不斷的被發送出去。
For($j = 1; $j <= 20; $j++) {
    echo $j."";
    flush(); //這一部會使cache新增的內容被擠出去,顯示到瀏覽器上
    sleep(1); //讓程序"睡"一秒鐘,會讓你把效果看得更清楚
}
?>

注:如果在程序的首部加入ob_implicit_flush()打開絕對刷新,就可以在程序中不再使用flush(),這樣做的好處是:提高效率!

2. 關于ob系列函數:
我想先引用我的好朋友y10k 的一個例子:
Example 3.

比如你用得到服務器和客戶端的設置信息,但是這個信息會因為客戶端的不同而不同,如果想要保存 phpinfo()函數的輸出怎么辦呢?在沒有緩沖區控制之前,可以說一點辦法也沒有,但是有了緩沖區的控制,我們可以輕松的解決:

<?php
ob_start(); //打開緩沖區
phpinfo(); //使用phpinfo函數
$info=ob_get_contents(); //得到緩沖區的內容并且賦值給$info
$file=fopen(\'info.txt\',\'w\'); //打開文件info.txt
fwrite($file,$info); //寫入信息到info.txt
fclose($file); //關閉文件info.txt
?>

用以上的方法,就可以把不同用戶的phpinfo信息保存下來,這在以前恐怕沒有辦法辦到!其實上面就是將一些"過程"轉化為"函數"的方法!
或許有人會問:"難道就這個樣子嗎?還有沒有其他用途?"當然有了,比如筆者論壇的PHP 語法加亮顯示就和這個有關(PHP默認的語法加亮顯示函數會直接輸出,不能保存結果,如果在每次調用都顯示恐怕會很浪費CPU,筆者的論壇就把語法加亮函 數顯示的結果用控制緩沖區的方法保留了)!

可能現在大家對ob_start()的功能有了一定的了解,上面的一個例子看似簡單,但實際上已經掌握了使用ob_start()的要點。
<1>. 使用ob_start打開browser的cache,這樣可以保證cache的內容在你調用flush(),ob_end_flush()(或程序執行完畢)之前不會被輸出。
<2>.現在的你應該知道你所擁有的優勢:可以在任何輸出內容后面使用header,setcookie以及 session,這是ob_start一個很大的特點;也可以使用ob_start的參數,在cache被寫入后,然后自動運行命令,比如 ob_start(\"ob_gzhandler\");而我們最常用的做法是用ob_get_contents()得到cache中的內容,然后再進行 處理……
<3>.當處理完畢后,我們可以使用各種方法輸出,flush(),ob_end_flush(),以及等到程序執行完畢后的自動輸出。當然,如果你用的是ob_get_contents(),那么就要你自己控制輸出方式了。

來,讓我們看看能用ob系列函數做些什么……

一、 靜態模版技術

簡介:所謂靜態模版技術就是通過某種方式,使得用戶在client端得到的是由PHP產生的html頁面。如果這個html頁面不會再被更新,那么 當另外的用戶再次瀏覽此頁面時,程序將不會再調用PHP以及相關的數據庫,對于某些信息量比較大的網站,例如sina,163,sohu。類似這種的技術 帶來的好處是非常巨大的。

我所知道的實現靜態輸出的有兩種辦法:
<1>. 通過y10k修改的phplib的一個叫template.inc.php類實現。
<2>.使用ob系列函數實現。
對于第一種方法,因為不是這篇文章所要研究的問題,所以不再贅述。
我們現在來看一看第二種方法的具體實現:
Example 4.

<?php
ob_start();// 打開緩沖區
?>

php頁面的全部輸出

<?
$content = ob_get_contents();//取得php頁面輸出的全部內容
$fp = fopen("output00001.html", "w"); //創建一個文件,并打開,準備寫入
fwrite($fp, $content); //把php頁面的內容全部寫入output00001.html,然后……
fclose($fp);
?>

這樣,所謂的靜態模版就很容易的被實現了……

二、 捕捉輸出

以上的Example 4.是一種最簡單的情況,你還可以在寫入前對$content進行操作……
你可以設法捕捉一些關鍵字,然后去對它進行再處理,比如Example 3.所述的PHP語法高亮顯示。個人認為,這個功能是此函數最大的精華所在,它可以解決各種各樣的問題,但需要你有足夠的想象力……
Example 5.

<?
Function run_code($code) {
    If($code) {
        ob_start();
        eval($code);
        $contents = ob_get_contents();
        ob_end_clean();
    }else {
        echo "錯誤!沒有輸出";
        exit();
    }
    return $contents;
}

以上這個例子的用途不是很大,不過很典型$code的本身就是一個含有變量的輸出頁面,而這個例子用eval把$code中的變量替換,然后對輸出結果再進行輸出捕捉,再一次的進行處理……

Example 6. 加快傳輸

<?
/*
** Title.........: PHP4 HTTP Compression Speeds up the Web
** Version.......: 1.20
** Author........: catoc <----escape_autolink_uri:<a href="mailto:eec569f40d22f3c6f0e5d9632a155b5d----catoc@163.net----escape_autolink_uri">eec569f40d22f3c6f0e5d9632a155b5d----catoc@163.net----escape_autolink_uri</a>:fd02c263d83a2a02d7bb75936793c84f---->
** Filename......: gzdoc.php
** Last changed..: 18/10/2000
** Requirments...: PHP4 >= 4.0.1
** PHP was configured with --with-zlib[=DIR]
** Notes.........: Dynamic Content Acceleration compresses
** the data transmission data on the fly
** code by sun jin hu (catoc) <----escape_autolink_uri:<a href="mailto:eec569f40d22f3c6f0e5d9632a155b5d----catoc@163.net----escape_autolink_uri">eec569f40d22f3c6f0e5d9632a155b5d----catoc@163.net----escape_autolink_uri</a>:fd02c263d83a2a02d7bb75936793c84f---->
** Most newer browsers since 1998/1999 have
** been equipped to support the HTTP 1.1
** standard known as \"content-encoding.\"
** Essentially the browser indicates to the
** server that it can accept \"content encoding\"
** and if the server is capable it will then
** compress the data and transmit it. The
** browser decompresses it and then renders
** the page.
**
** based on ideas by Sandy McArthur, Jr
** Usage........:
** No space before the beginning of the first \'<?\' tag.
** ------------Start of file----------
** |<?
** | include(\'gzdoc.php\');
** |? >
** |<HTML>
** |... the page ...
** |</HTML>
** |<?
** | gzdocout();
** |? >
** -------------End of file-----------
*/
ob_start();
ob_implicit_flush(0);
function CheckCanGzip(){
    global $HTTP_ACCEPT_ENCODING;
    if (headers_sent() || connection_timeout() || connection_aborted()){
        return 0;
    }
    if (strpos($HTTP_ACCEPT_ENCODING, \'x-gzip\') !== false) return \"x-gzip\";
    if (strpos($HTTP_ACCEPT_ENCODING,\'gzip\') !== false) return \"gzip\";
    return 0;
}
 
/* $level = compression level 0-9, 0=none, 9=max */
function GzDocOut($level=1,$debug=0){
    $ENCODING = CheckCanGzip();
    if ($ENCODING){
        print \"n<!-- Use compress $ENCODING -->n\";
        $Contents = ob_get_contents();
        ob_end_clean();
 
        if ($debug){
            $s = \"<p>Not compress length: \".strlen($Contents);
            $s .= \"
            Compressed length: \".strlen(gzcompress($Contents,$level));
            $Contents .= $s;
        }
        header(\"Content-Encoding: $ENCODING\");
        print \"x1fx8bx08x00x00x00x00x00\";
        $Size = strlen($Contents);
        $Crc = crc32($Contents);
        $Contents = gzcompress($Contents,$level);
        $Contents = substr($Contents, 0, strlen($Contents) - 4);
        print $Contents;
        print pack(\'V\',$Crc);
        print pack(\'V\',$Size);
        exit;
    }else{
        ob_end_flush();
        exit;
    }
}
?>

這是catoc的一段很早以前的代碼,是在weblogs.com看到的,他利用了zlib的函數,對傳輸的內容進行了壓縮,測試表明,對于10k以上的頁面,會產生效果,而且頁面越大,效果越明顯……

 

incode 發表在 痞客邦 留言(1) 人氣()

function Pass($i=8) {
    srand((double)microtime()*987654321);
    return strtoupper(substr(md5(uniqid(rand())),rand(0,32-$i),$i));
}
 
$checkcode =  Pass(20); // 丟出8碼

incode 發表在 痞客邦 留言(0) 人氣()

  <link href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8/themes/base/jquery-ui.css" rel="stylesheet" type="text/css"/>
  <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js"></script>
  <script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8/jquery-ui.min.js"></script>
 
  <script>
  $(document).ready(function() {
    $("#datepicker").datepicker({ dateFormat: 'yyyy-mm-dd' });
  });
  </script>


另外jQuery UI的主題css列表
http://encosia.com/2009/10/11/do-you-know-about-this-undocumented-google-cdn-feature/

incode 發表在 痞客邦 留言(0) 人氣()

  • 尋找字串(search)
    stringObject.search(searchstring)
    stringObject.search(尋 找的字串)
    大小寫必須相符

    var str = "test String";
    alert(str.search("Str"));
    alert(str.search("str"));
    輸出結果:5
    輸出結果:-1




  • 傳回字串 內相符的字串(match)
    無相符字串則傳回null,大小寫要相符

    var str = "test String";
    alert(str.match("TEST"));
    alert(str.match("Str"));
    輸出結果:null
    輸出結果:Str

  • 取得字串長度(length)
    var str = "test String";
    alert(str.length);
    輸出結果:11




  • 尋找某字串在字串內的位置(indexOf)
    stringObject.indexOf(searchvalue,fromindex)
    stringObject.indexOf (尋找的字串,開始尋找的位置)

    var str = "test String";
    alert(str.indexOf("Str"));
    alert(str.indexOf("Str",6));
    輸出結果:5
    輸出結果:-1




  • 從後往前找某字串在字串內的位置(lastIndexOf)
    stringObject.lastIndexOf(searchvalue,fromindex)
    stringObject.lastIndexOf (尋找的字串,開始尋找的位置)

    var str = "test String";
    alert(str.lastIndexOf("Str"));
    alert(str.lastIndexOf("Str",2));
    alert(str.lastIndexOf("Str",10));
    輸出結果:5
    輸出結果:-1
    輸出結果:5





  • 變更英文字大小寫
    toUpperCase() 大寫
    toLowerCase() 小寫

    var str = "test String";
    alert(str.toUpperCase());
    alert(str.toLowerCase());
    輸出結果:TEST STRING
    輸出結果:test string





  • 傳回字串內某位置的字元(charAt)
    stringObject.charAt(index)
    位 置由0開始

    var str = "test String";
    alert(str.charAt(3));
    alert(str.charAt(7));
    輸出結果:t
    輸出結果:r


  • 傳 回參數中以Unicode值所代表的字元組成的字串(fromCharCode)
    String.fromCharCode(numX,numX,...,numX)
    alert(String.fromCharCode(65,66,67));
    輸 出結果:ABC





  • 傳回字串內某位置區間的字串(substring & substr)
    stringObject.substring(start,stop)
    stringObject.substring(開 始位置,結束位置)
    stringObject.substr(start,length)
    stringObject.substr(開始 位置,字串長度)
    (開始位置)若為負數則由後往前數,但不適用於IE

    alert("0123456789".substring(4,6))
    alert("0123456789".substr(4,6))
    輸出結果:45
    輸出結果:456789





  • 字串取代(replace)
    stringObject.replace(findstring,newstring)
    stringObject.replace(要 找尋的字串,換成新的字串)
    大小寫必須相符

    var str = "test String";
    alert(str.replace("string", "Text"));
    alert(str.replace("String", "Text"));
    輸出結果:test String
    輸出結果:test Text





  • 組合字串(concat)
    stringObject.concat(stringA,stringB,...,stringX)
    stringObject.concat(字 串A,字串B,...,字串X)

    var strA = "test ";
    var strB = "String";
    alert(str1.concat(str2));
    輸出結果:test String





  • 取得切割字串(slice)
    stringObject.slice(start,end)
    stringObject.slice(開 始位置,結束位置)

    var str = "test String";
    alert(str.slice(5));
    alert(str.slice(0,4));
    輸出結果:String
    輸出結果:test




  • 分割字串(split)
    stringObject.split(separator, howmany)
    stringObject.split(分割字串, 分割後各字串的字元數)

    var str = "test String";
    alert(str.split(""));
    alert(str.split(" ",4));
    輸出結果:t,e,s,t, ,S,t,r,i,n,g
    輸出結果:test,String

 

文章轉自 http://miisoo.blogspot.com/2008/01/javascript-string-operations.html

incode 發表在 痞客邦 留言(0) 人氣()

//------  透過linux時間排序 開始----------
        function cmp_ay( $ar1, $ar2 )
        {
            $la = strtotime($ar1['date']);
            $lb = strtotime($ar2['date']);
            //echo "$la:$lb <br />";
            
            
            if ($la<$lb)
                return -1;
            else if ($la>$lb)
                  return 1;
                  
            /*if ($ar1['type']<$ar2['type'])
                return -1;
            else if ($ar1['type']>$ar2['type'])
                return 1;*/
            return 0;
        }

        usort($all_list, 'cmp_ay');

        

//------  透過linux時間排序 結束----------

incode 發表在 痞客邦 留言(1) 人氣()

PHP部份

<?php
require_once('../Connections/con_Set.php');


foreach($_GET AS $key => $value) { $_GET[$key] = mysql_real_escape_string($value); }

$sql = <<<sql
SELECT dr.name, dr.did, ci.license, ci.car_category, dr.phone, com.name AS com_name, ci.brand, ci.cc
FROM tr_car_inf ci, tr_driver dr, tr_company com
WHERE ci.cid = com.cid
AND ci.did = dr.did
sql;

if ($_GET['driver']!=null) $sql .= "AND `dr`.`name` LIKE '%{$_GET['driver']}%' ";
if ($_GET['license']!=null) $sql .= "AND `ci`.`license` LIKE '%{$_GET['license']}%' ";
if ($_GET['phone']!=null) $sql .= "AND `dr`.`phone` LIKE '%{$_GET['phone']}%' ";
if ($_GET['com_name']!=null) $sql .= "AND `com`.`name` LIKE '%{$_GET['com_name']}%' ";
if ($_GET['car_category']!=null) $sql .= "AND `ci`.`car_category` LIKE '%{$_GET['car_category']}%' ";
if ($_GET['brand']!=null) $sql .= "AND `ci`.`brand` LIKE '%{$_GET['brand']}%' ";
if ($_GET['cc']!=null) $sql .= "AND `ci`.`cc` LIKE '%{$_GET['cc']}%' ";

$sql .=<<<sql
ORDER BY `dr`.`name` ASC
sql;

//echo $sql;
$data_array = array();


$result = mysql_query($sql) or trigger_error(mysql_error());
while($row = mysql_fetch_array($result)){
    
     $data_array[] = array
            (
                "driver" => $row['name'],
                "license" => $row['license'],
                "phone" => $row['phone'],
                "com_name" => $row['com_name'],
                "car_category" => $row['car_category'],
                "brand" => $row['brand'],
                "cc" => $row['cc']
            );
        
}
 
echo json_encode($data_array);

 


 

PHP讀取頁


echo <<<html
<script type="text/javascript">
$().ready(function() {
    
  $("input").blur(function(){
    $("tr").remove(".db_list");
    $("tr").remove(".s_list");
    
    jQuery.event.trigger( "ajaxStop" );
    var inputv = $("input[type=text]").serialize();
    
    /*var req = $(this).attr("id");
    var value = $(this).val();
    alert (inputv);*/
    
    $.ajax({
        url: "$jsonurl?" + inputv,
        type: "GET",
        dataType: "json",
        success: function(Ddata) {
            var i = 0;
        $.each(Ddata, function() {
        $("table.driver_list").append("<tr class=\"s_list\">" +
                            "<td>" +  (i+1) + "</td>" +
                            "<td>" + Ddata[i].driver   + "</td>" +
                            "<td>" + Ddata[i].license   + "</td>" +
                            "<td>" + Ddata[i].phone   + "</td>" +
                            "<td>" + Ddata[i].com_name.substring(0,2)    + "</td>" +
                            "<td>" + Ddata[i].car_category + "</td>" +
                            "<td>" + Ddata[i].brand + "</td>" +
                            "<td>" + Ddata[i].cc + "</td>" +
                            "<td><a href=\"$in_url?lic=" +  Ddata[i].license + "\">編輯</a></td>" +
                            "</tr>");
        i++;
        });
    },
 
        Error: function() {
            alert("ERROR!!!");
        }
    });
    $("#loading").ajaxStart(function(){
    $(this).show();
    });
    
    $("#loading").ajaxStop(function(){
    $(this).hide();
    });
    
  })//keyup end
 
})
</script>
<table width="800" border="1">
  <tr>
    <td></td>
    <td><input name="driver" type="text" id="driver" size="10"/></td>
    <td><input name="license" type="text" id="license" size="10"/></td>
    <td><input name="phone" type="text" id="phone" size="14"/></td>
    <td><input name="com_name" type="text" id="com_name" size="6"/></td>
    <td><input name="car_category" type="text" id="car_category" size="10"/></td>
    <td><input name="brand" type="text" id="brand" size="12"/></td>
    <td><input name="cc" type="text" id="cc" size="8"/></td>
    <td></td>
  </tr>
  <tr id="head">
    <td>編號</td>
    <td>車主</td>
    <td>牌照號碼</td>
    <td>手機</td>
    <td>車行</td>
    <td>車種</td>
    <td>廠牌</td>
    <td>CC數</td>
    <td>功能</td>
  </tr>
  <tr id="loading" style="display:none;text-align:center">
    <td colspan="9"><img src="{$base_theme_url}images/load.gif" width="24" height="24" /></td>
  </tr>
html;

incode 發表在 痞客邦 留言(0) 人氣()


$sql = "SELECT `cid`, `sname` From `tr_company`";
$result = mysql_query($sql) or trigger_error(mysql_error());

$select_c = '<select name="cid">';
while($company = mysql_fetch_array($result)){
$tag = $company['sname'];
$value = $company['cid'];

$select_c .= "<option value=\"$value\" ";
    if ($value == $row['cid']){
        $select_c .= 'selected="selected"';
    }    
$select_c .= ">$tag</option>";
}
$select_c .= '</select>';


incode 發表在 痞客邦 留言(0) 人氣()

利用jQuery的serialize來取得所有 input的type=’text’值

$("input[@type=text]").serialize(); <= 此為 1.3版本以前的寫法
$("input[type=text]").serialize(); <= 1.3版本後的寫法

用這組合網址拿去ajax用輕鬆很多,不用再一個個判斷,剩下的當空即可。


//這個好像是autocomplete用的
$(".owner").result(function(event, data, formatted) {
        var dr_name = $(this).parent().next().find(">:input");
        dr_name.val( (dr_name.val() ? dr_name.val() + ";" : dr_name.val()) + data[2]);
        var dr_did = $(this).parent().find(":input").eq(1);
        dr_did.val(data[1]);

            
    })

 


//用來計算總計,當blur就在一個位置算總值
<script type="text/javascript">
$().ready(function() {

    //總計
    function ins_count ()
    {
        var casualty,property,employer,total = 0;
        casualty = parseInt($('#is_any_pr_casualty').val());
        property = parseInt($('#is_any_pr_property').val());
        employer = parseInt($('#is_any_pr_employer').val());
        

        total = casualty + property + employer;
        total = parseInt(total);
        $('#is_any_total_pr').val(total);
            
    };
        
    $("#count_ins").click(function(){
            ins_count ();
    });  
    
    $("#is_any_pr_casualty, #is_any_pr_property, #is_any_pr_employer").blur(function(){
        ins_count ();
    
    });
    
    
    
});
</script>

 


//用來計算民國加一年(此格日期輸入後blur另一格就算出下一年)

<script type="text/javascript">
$().ready(function() {

   
    //---日期加一年----   
    $("#is_sta").blur(function(){
       
        var check = $(this).val().substr(0,1);
        if (check == 9)
        {
        var thisyear = $(this).val().substr(0,2);
        var thismd = $(this).val().substr(2,4);
        }else{
       
        var thisyear = $(this).val().substr(0,3);
        var thismd = $(this).val().substr(3,4);
        }
        thisyear = Number(thisyear);
        nextyear = thisyear + 1;
        //String
        $("#is_end").val(nextyear + thismd)
       
       
    }); 
   

});

</script>

 


 

 

 

Autocomplete

incode 發表在 痞客邦 留言(0) 人氣()

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.2.6/jquery.min.js"></script>  
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.5.2/jquery-ui.min.js"></script>  

<script type="text/javascript" src="http://www.google.com/jsapi"></script>
<script type="text/javascript" language="javascript">
google.load("jquery", "1.2");
google.load("jqueryui", "1.5.2"); // 不用 jQuery UI 可以不用此行
</script>

<script type="text/javascript">    
     $(function() {    
         你的程式碼
   });    
</script>

incode 發表在 痞客邦 留言(0) 人氣()

//int GET的資料
if (isset($_GET['is_id']) ) {
$is_id = (int) $_GET['is_id'];

 


//資料庫插入檢測是否有不合法字
foreach($_POST AS $key => $value) { $_POST[$key] = mysql_real_escape_string($value); }

 

 

//計算筆數
$cr = mysql_query("SELECT COUNT(nil_id) FROM tr_noti_list Where nid = $nid");
$cr = mysql_fetch_row($cr);
$list_c = $cr[0];

 

 

// sql 關聯查詢
$sql = <<
SELECT ci.license, ci.cid, ci.did as driver_code, ci.office_exp, ci.cc, ci.fuelTax, ci.licenseTax, dr.name as driver, com.name as com_name
FROM tr_car_inf ci, tr_driver dr, tr_company com
WHERE ci.cid = com.cid
AND ci.did = dr.did
ORDER BY `dr`.`name` ASC
sql;


$result = mysql_query($sql) or trigger_error(mysql_error());
while($row = mysql_fetch_array($result)){

    foreach($row AS $key => $value) { //if ($value == null) $value = "&nbsp;";
    $row[$key] = stripslashes($value);
    }

}

 

 


//表單傳送控制,方便整理
if (isset($_POST['submitted'])) {

 

}

<input type='hidden' value='1' name='submitted' />

 

 

PHP陣列轉成文字檔

//轉成文字並用base64加密
$ni_list = base64_encode(serialize($all_list));

//轉回陣列
$all_list = unserialize(base64_decode($all_list));

相關問題處理,轉貼自http://cychiang719.blogspot.com/2009/03 /phpserializeunserialize.html

由於要顯示在textbox裡,用上述方法還是會有漏洞
試了很久,下面這順序應該是比較理想
1.寫入資料庫時,只做 urlencode(若要使用addslashes,則在這之前)
  例:$a=urlencode(addslashes($text));
2.前端顯示時,則先解開,然後將slashes去掉,再用htmlspecialchars
  例:$a=htmlspecialchars(stripslashes(urldecode($dbValue)));

 

//擷取字串中的幾個字
substr($word,0,6);

 

//組合式陣列去除陣列最後一筆(例如用||區分,因為加到最後一筆以後,使用explode最後一筆陣列會是空。
$records = explode('||', $_POST['postdata']);
$nou = array_pop($records); //切割後最右邊是空,所以拿掉

 

//處理陣列 (單引號處理掉,防止sql注入)
//也就是將POST的資料全部使用mysql_real_escape_string處理過組成$des新陣列。
$des = $_POST;
foreach ($_POST as $k=>$v) {
    $des[$k] = mysql_real_escape_string($v);
}

//用來看陣列資料
foreach($des as $key_name => $value) {
    echo $key_name . " = " . $value . "<br>";
}

incode 發表在 痞客邦 留言(0) 人氣()

«12 3