PHP网站大量照片存储,webcam html5+PHP 实现网站调用摄像头拍照,存储照片和照片预览功能...

1HTML

2JS

webcam.set_api_url('{{url('stu/action')}}');

webcam.set_quality(90); // JPEG quality (1 - 100)

webcam.set_shutter_sound(true); // play shutter click sound

$('#camera').html(webcam.get_html(240, 320, 300, 420));

webcam.set_hook('onComplete', 'my_completion_handler');

function take_snapshot() {

var card_id = $("#card_id").val();

var sname = $('#sname').val();

if (card_id == null || card_id == '' || sname == null || sname == '') {

alertMsg.warn('请先完善身份信息');

} else {

document.all['base64'].src = "";

// take snapshot and upload to server

webcam.snap();

}

}

function my_completion_handler(msg) {

// extract URL out of PHP output

if (msg.match(/(http\:\/\/\S+)/)) {

var image_url = msg.split('*');

// show JPEG image in page

var pic = image_url[image_url.length - 1];

alertMsg.correct('拍照成功');

$("#pic").attr("src", 'data:image/jpeg;base64,' + pic);

$("#base64").val(pic);

var card_id = $('#card_id').val();

var sname = $('#sname').val();

$("#photopath").val(card_id + sname + '.png');

// reset camera for another shot

webcam.reset();

}

else alertMsg.error("拍照失败");

}

3PHP

public function action()

{

$filename = date('YmdHis') . '.png';

$result = file_put_contents(storage_path() . '/photo/' . $filename, file_get_contents('php://input'));

if (!$result) {

print "ERROR: Failed to write data to $filename, check permissions\n";

exit();

}

$path = storage_path() . '/photo/' . $filename;

$base64_img = $this->base64EncodeImage($path);

unlink($path);

$url = 'http://' . $_SERVER['HTTP_HOST'] . dirname($_SERVER['REQUEST_URI']) . '*' . $base64_img;

Log::info($url);

print "$url\n";

}

最后实现了拍照存储预览,功能实现的基本源码https://download.csdn.net/download/qq_29099209/10563094,如需以上功能则根据上述代码修改即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值