PHP函数封装! 150

$arr=$_POST;$sql="INSERTINTOui234_user(username,password,u_name,u_time)VALUES(?,?,?,?... $arr=$_POST;
$sql="INSERT INTO ui234_user (username,password,u_name,u_time) VALUES (?,?,?,?)";

$mysqli=connect();
$stmt = $mysqli->prepare("{$sql}");
$stmt->bind_param('ssss',$arr['username'],$arr['password'],$arr['u_name'],$arr['u_time']);
$stmt->execute();

新手,做了一个代码,但是想封装他,查了好久的资料不会弄,高手帮忙写下!
POST过来的是一个数组,是需要插入的值。传入一个SQL语句!
类似于这样:
$arr=$_POST;
$sql="INSERT INTO ui234_user (username,password,u_name,u_time) VALUES (?,?,?,?)";
function insert($arr,$sql){
$mysqli=connect();
$stmt = $mysqli->prepare("{$sql}");
$stmt->bind_param('ssss', /* 这个位置该如何实现上面代码那样,通过传值?*/ );
$stmt->execute();
}
//添加数据方法,用我给出的代码实现,解决后再加100份,真心感谢!
展开
 我来答
ouyangqunli101
推荐于2017-11-27 · TA获得超过667个赞
知道小有建树答主
回答量:421
采纳率:100%
帮助的人:191万
展开全部

你传入的sql不应该那样传,可用性太低,函数或方法应该传入变量,或者说可变的值。上代码,不懂的问

/*封装函数*/
$arr = $_POST;
//$sql = "INSERT INTO ui234_user (username,password,u_name,u_time) VALUES (?,?,?,?)";
$table_name = "ui234_user";
$field_arr = array('username','password','u_name','u_time');

insert($arr,$table_name,$field_arr);

function insert($arr,$table_name,$field_arr){
    $sql = 'INSERT INTO '.$table_name.' (';
    $field_name = '';//名称
    $field_value = '';//值
    $field_post = '';//post取值
    /*拼装字段*/
    foreach ($field_arr as $key => $value) {
         if($key == count($field_arr)-1){
         $field_name .= $value;
         $field_value.= '?';
         $field_post .= '$arr["'.$field_name.'"]';
         }else{
         $field_name .= $value.',';
         $field_value.= '?,';
         $field_post .= '$arr["'.$value.'"],';
         }
    }
    $sql .= $field_name.') VALUES ('.$field_value.');';

    $mysqli=connect();
    $stmt = $mysqli->prepare("{$sql}");
    $exe_str = '$stmt->bind_param("ssss",'.$field_post.');';
    //输出字符串结果
    echo $sql.'<hr/>';
    echo $exe_str;

    //然后用eval执行字符串代码
    eval($exe_str);//相当于是:$stmt->bind_param('ssss',$arr['username'],$arr['password'],$arr['u_name'],$arr['u_time']);

    stmt->execute();
}
自由的人07
2015-08-29 · TA获得超过6862个赞
知道小有建树答主
回答量:523
采纳率:66%
帮助的人:152万
展开全部
php的封装就是把要封装的代码携程一个函数,然后在页面里面调用,asp.net是把某些代码封装成dll文件调用,php是把代码封装成函数调用,当然也可以对封装的代码进行加密。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式