前段时间做视频上传业务,通过网页上传视频到服务器。

视频大小 小则几十M,大则 1G+,以一般的HTTP请求发送数据的方式的话,会遇到的问题:1,文件过大,超出服务端的请求大小限制;2,请求时间过长,请求超时;3,传输中断,必须重新上传导致前功尽弃;

 

解决方案:

1,修改服务端上传的限制配置;Nginx 以及 PHP 的上传文件限制 不宜过大,一般5M 左右为好;

2,大文件分片,一片一片的传到服务端,再由服务端合并。这么做的好处在于一旦上传失败只是损失一个分片而已,不用整个文件重传,而且每个分片的大小可以控制在4MB以内,服务端限制在4M即可。

前端

Web前端可使用HttpUploader6的大文件上传控件6;官网地址:http://t.cn/EyI6vHh 

<div class="section section6 section5">

    <div class="part1"><a href="javascript:;" target="_blank" class="part1__btn">批量删除</a><span class="part1__txt"><em class="part1__num" id="upload_num">0</em>个视频,共 <em class="part1__num" id="upload_size">0M</em></span></div>

    <table class="section5__table">

        <tbody id="thelist">

            <tr class="thead">

                <th class="col1 allCkeck"><input type="checkbox" name="" class="col1__checkBox"/>视频名称</th><th class="col2">视频大小</th><th class="col3">视频分类</th><th class="col4">状态</th><th class="col5">进度</th><th>操作</th>

            </tr>

        </tbody>

    </table>

    <div class="selFile" id="selFile">

        <div id="drag_tips">

            <div id="btns__add2"></div>

            <h2 class="txt1">选择视频文件</h2>

            <span class="txt2">或直接将文件拖拽至此窗口</span>

        </div>

    </div>

    <div class="btns"><span class="btns__add" id="btns__add">+添加视频文件</span><span class="btns__upload btns__upload-start" id="uploadBtn"><i class="btns__upload_icon"></i>开始上传视频</span></div>

</div>

//引入插件

<script type="text/javascript" src="media/js/lib/webuploader/js/webuploader.min.js"></script>

upload.js

1 // 文件上传

2 jQuery(function() {

3     var $ = jQuery,

4         $list = $('#thelist'),

5         $btn = $('#upload-start'),

6         $thead = $('.thead'),

7         $part_btn = $('.part1__btn'), //批量上传按钮

8         state = 'pending',

9         fileCount = 0, //上传文件总数

10         fileSize = 0,//上传文件的总大小

11     // 上传按钮

12         $upload = $('#uploadBtn'),

13     // 所有文件的进度信息,key为file id

14         percentages = {},

15     // 所有文件的md5,key为file id

16         md5Obj = {},

17     // 可能有pedding, ready, uploading, confirm, done.

18         state = 'pedding',

19         uploader;

20

21     //浏览器关闭提醒

22     window.is_confirm = false;

23     $(window).bind('beforeunload', function(){

24         // 只有在标识变量is_confirm不为false时,才弹出确认提示

25         if(window.is_confirm !== false)

26             return '正在上传视频,该操作将丢失视频,是否继续?';

27     })

28

29     if ( !WebUploader.Uploader.support() ) {

30         alert( 'Web Uploader 不支持您的浏览器!如果你使用的是IE浏览器,请尝试升级浏览器');

31         throw new Error( 'WebUploader does not support the browser you are using.' );

32     }

33

34     $(".pop2 .btns__sure").click(function(){

35         $('.popup,.pop').hide();

36     });

37

38     uploader = WebUploader.create({

39         //拖拽容器

40         dnd:'#selFile',

41

42         // 不压缩image

43         resize: false,

44

45         // swf文件路径

46         swf: '/media/js/lib/webuploader/js/Uploader.swf',

47

48         // 文件接收服务端。

49         server: '/service/upload/upload_file',

50         //server:'http://vod.test.4399sy.com/service/upload/ssl_upload_file',

51         formData: {

52             file_id: 'file',

53             guid:new Date().getTime() + Math.ceil(Math.random()*100),

54             file_name:''

55         },

56

57         // 选择文件的按钮。可选。

58         // 内部根据当前运行是创建,可能是input元素,也可能是flash.

59         pick: {

60             id:'#btns__add',

61             innerHTML:"+添加视频文件"

62         },

63

64         // 开起分片上传。

65         chunked: true,

66

67         //如果要分片,分多大一片2M

68         chunkSize:2*1024*1024,

69

70         //上传文件的类型

71         accept:{

72             title: 'Videos',

73             extensions: 'mp4,avi,flv',

74             mimeTypes: 'video/*'

75         },

76         //验证文件总数量, 超出则不允许加入队列。

77         fileNumLimit: 10,

78         //单个文件上传的大小限制 2G

79         fileSingleSizeLimit:2*1024*1024*1024,

80

81     });

82

83     //添加文件具体函数

84     function addFile( file ){

85         var data = new Date(),

86             month = (data.getMonth()+1)<10 ? '0'+(data.getMonth()+1) : (data.getMonth()+1),

87             day = data.getDate()<10 ? '0'+ data.getDate(): data.getDate(),

88             time = data.getFullYear() + "-" + month + "-" + day,

89             $tr = $('<tr class="toBeUploaded" id="'+file.id+'"></tr>'),

90             $td = $('<td class="col1"><input type="checkbox" name="" class="col1__checkBox"/><input type="text" value="'+ file.name +'" name="" class="name"/></td><td class="col2">'+convert_size(file.size)+'</td><td class="col3"><select class="class_id">'+ class_options +'</select></td><td class="col4">读取视频中</td><td class="col5">0%</td><td class="col6"><ul><li class="view"><a target="_blank" href="javascript:;">查看</a></li><li class="delete">删除</li></ul></td>').appendTo($tr),

91             $state = $tr.find('td.col4'),

92             $prgress = $tr.find('td.col5'),

93             $delbtn = $tr.find('li.delete');

94

95         $("#selFile").hide();

96

97         if ( file.getStatus() === 'invalid' ) {

98             switch( file.statusText ) {

99                 case 'exceed_size':

100                     text = '文件大小超出';

101                     break;

102

103                 case 'interrupt':

104                     text = '上传暂停';

105                     break;

106

107                 default:

108                     text = '上传失败,请重试';

109                     break;

110             }

111             showError(text);

112         } else {

113             // @todo lazyload

114             percentages[ file.id ] = [ file.size, 0 ];

115             file.rotation = 0;

116         }

117

118         file.on('statuschange', function( cur, prev ) {

119             if ( prev === 'progress' ) {

120                 //上传成功

121             } else if ( prev === 'queued' ) {

122                 // 开始上传

123             }

124

125             // 成功

126             if ( cur === 'error' || cur === 'invalid' ) {

127                 console.log( file.statusText );

128                 showError( file.statusText );

129                 percentages[ file.id ][ 1 ] = 1;

130             } else if ( cur === 'interrupt' ) {

131                 showError( 'interrupt' );

132             } else if ( cur === 'queued' ) {

133                 percentages[ file.id ][ 1 ] = 0;

134             } else if ( cur === 'progress' ) {

135             //   正在上传

136

137             } else if ( cur === 'complete' ) {

138             //   上传完成

139

140             }

141

142             $tr.removeClass( 'state-' + prev ).addClass( 'state-' + cur );

143         });

144         $delbtn.on('click',function(){

145             uploader.removeFile( file );

146         });

147         $tr.appendTo($list);

148         //$tr.insertAfter($thead);

149     }

150

151     // 负责view的销毁

152     function removeFile( file ) {

153         var $tr = $('#'+file.id);

154

155         delete percentages[ file.id ];

156         $tr.off().find('.col6').off().end().remove();

157     }

158

159     function setState( val ) {

160         var file, stats;

161

162         if ( val === state ) {

163             return;

164         }

165

166         $upload.removeClass( 'state-' + state );

167         $upload.addClass( 'state-' + val );

168         state = val;

169

170         switch ( state ) {

171             case 'pedding':

172                 uploader.refresh();

173                 break;

174

175             case 'ready':

176                 uploader.refresh();

177                 break;

178

179             case 'uploading':

180                 $upload.text( '暂停上传' );

181                 break;

182             case 'paused':

183                 $upload.text( '继续上传' );

184                 break;

185

186             case 'confirm':

187                 //$progress.hide();

188                 $upload.text( '开始上传' ).addClass( 'disabled' );

189

190                 stats = uploader.getStats();

191                 if ( stats.successNum && !stats.uploadFailNum ) {

192                     setState( 'finish' );

193                     return;

194                 }

195                 break;

196             case 'finish':

197                 stats = uploader.getStats();

198                 if ( stats.successNum ) {

199                     alert( '上传成功' );

200                 } else {

201                     // 没有成功的图片,重设

202                     state = 'done';

203                     location.reload();

204                 }

205                 break;

206         }

207     }

208

209

210     // 当有文件添加进来的时候

211     uploader.on( 'fileQueued', function( file ) {

212         fileCount++;

213         fileSize += file.size;

214         $("#upload_num").text(fileCount);

215         $("#upload_size").text(convert_size(fileSize));

216         md5Obj[ file.id ] = '';

217         //获取文件MD5 值

218         uploader.md5File( file )

219             // 及时显示进度

220             .progress(function(percentage) {

221                 $( '#'+file.id ).find('.col4').text('读取文件'+parseInt(percentage*100)+"%");

222             })

223             // 完成

224             .then(function(val) {

225             console.log('md5 result:', val);

226             md5Obj[ file.id ] = val;

227             $( '#'+file.id ).find('.col4').text('待上传');

228             setState( 'ready' );

229         });

230         addFile( file );

231     });

232

233     // 删除文件

234     uploader.onFileDequeued = function( file ) {

235         fileCount--;

236         fileSize -= file.size;

237         $("#upload_num").text(fileCount);

238         $("#upload_size").text(convert_size(fileSize));

239         if ( !fileCount ) {

240             setState( 'pedding' );

241         }

242         removeFile( file );

243

244     };

245

246     // 添加“添加文件”的按钮,

247     uploader.addButton({

248         id: '#btns__add2',

249         label: ''

250     });

251

252     // 文件上传过程中创建进度实时显示。

253     uploader.onUploadProgress = function( file, percentage ) {

254         var $tr = $('#'+file.id),

255             $percent = $tr.find('td.col5'),

256             $state = $tr.find('td.col4');

257         percentage = parseInt(percentage*100);

258         if(! (percentage == 0 && percentage == 100)){

259             $state.text("正在上传");

260         }

261         $percent.text( percentage + "%")

262         percentages[ file.id ][ 1 ] = percentage;

263     };

264

265     //上传前,请求服务端 判断文件是否已经上传过

266     uploader.on( 'uploadStart', function( file ) {

267         var type = 'POST';

268         var url = '/service/upload/determine_video_exist';

269         var request_data = {

270             'md5': md5Obj[ file.id ],

271             'type':1

272         };

273         var success = function(r) {

274             uploader.upload( file );

275             console.log(r);

276             if(r.code == 1) {

277                 uploader.skipFile( file );

278                 $( '#'+file.id ).find('.col4').text('视频已存在');

279                 $( '#'+file.id ).find('.col5').text('100%');

280                 $('#'+file.id).find('.view').find('a').attr('href',playmain +'/?video_id='+ r.data.video_id);

281                 $('.pop2 .video_game').text("所在游戏:"+r.data.game_name);

282                 $('.pop2 .create_time').text("上传时间:"+r.data.create_time);

283                 $('.pop').hide();

284                 $('.pop2').show();

285                 $('.popup').show();

286             }else if(r.code <= 0) {

287                 showError(r.msg);

288             }else {

289

290             }

291         };

292         request(type, url, request_data, success);

293     });

294

295     //当某个文件的分块在发送前触发,主要用来询问是否要添加附带参数,大文件在开起分片上传的前提下此事件可能会触发多次。

296     uploader.on('uploadBeforeSend', function (obj, data, headers) {

297         $tr = $("#"+data.id);

298         var file_name = $tr.find(".name").val();

299         var class_id = $tr.find("select.class_id").val();

300         var reg = /[1-9][0-9]*/g;

301         data.md5 = md5Obj[ obj.file.id ];

302         data.file_name = file_name;

303         data.class_id = class_id;

304         data.guid = data.guid + data.id.replace(/[^0-9]+/g, '');

305     });

306

307     uploader.on( 'uploadSuccess', function( file ,res) {

308         if(res.code == 1){

309             $( '#'+file.id ).find('.col4').text('成功上传');

310             console.log(res);

311             $('#'+file.id).find('.view').find('a').attr('href',playmain +'/?video_id='+ res.data.video_id);

312         }else if(res.code == 2) {

313             $( '#'+file.id ).find('.col4').text('视频已存在');

314             console.log(res);

315             $('#'+file.id).find('.view').find('a').attr('href',playmain +'/?video_id='+ res.data.video_id);

316         }else {

317             showError(res.msg);

318         }

319     });

320

321     uploader.on( 'uploadError', function( file,reason ) {

322         $( '#'+file.id ).find('.col4').text('上传失败');

323         console.log(reason);

324     });

325

326     uploader.on( 'uploadComplete', function( file ) {

327         $( '#'+file.id ).find('.progress').fadeOut();

328     });

329

330     uploader.on( 'all', function( type ) {

331         if ( type === 'startUpload' ) {

332             state = 'uploading';

333         } else if ( type === 'stopUpload' ) {

334             state = 'paused';

335         } else if ( type === 'uploadFinished' ) {

336             state = 'done';

337         }

338

339         if ( state === 'uploading' ) {

340             window.is_confirm = true;

341             $('.toBeUploaded').addClass("uploaded").removeClass("toBeUploaded");

342             $('input.name').attr("disabled","disabled");

343             $('input.col1__checkBox').hide();

344             $('input').attr("disabled","disabled");

345             $('select.class_id').attr("disabled","disabled");

346             $('.btns__add').remove();

347             $upload.addClass("btns__upload-ing").removeClass("btns__upload-start").html('<i class="btns__upload_icon"></i>正在上传视频');

348

349         } else if(state === 'done') {

350             window.is_confirm = false;

351             console.log("上传完成");

352             $upload.addClass("btns__upload-start btns__upload-refresh").removeClass("btns__upload-ing").html('<i class="btns__upload_icon"></i>开始上传视频');

353         }

354     });

355

356     /**

357      * 验证文件格式以及文件大小

358      */

359     uploader.on("error",function (type){

360         var msg = ''

361         switch (type){

362             case "Q_TYPE_DENIED": msg = "请上传mp4格式文件";break;

363             case "F_EXCEED_SIZE": msg = "文件大小不能超过1G";break;

364             case "Q_EXCEED_NUM_LIMIT" : msg = "一次最多能上传10个文件";break;

365             default: msg='';

366         }

367         if(msg != ''){

368             showError(msg);

369         }

370     });

371

372     $part_btn.on('click',function(){

373         $('td .col1__checkBox').each(function(){

374             if($(this).is(':checked')){

375                 var $tr = $(this).parents('tr');

376                 var id = $tr.attr('id');

377                 uploader.removeFile( id );

378             }

379         });

380     });

381     $upload.on('click', function() {

382         var isbreak = false;

383         $(".name").each(function(){

384             if(!$(this).val()|| $(this).val() == ''){

385                 isbreak = true;

386             }

387         })

388         if(isbreak){

389             showError("文件名不能存在为空");

390             return;

391         }

392         $("select.class_id").each(function(){

393             if(!$(this).val()|| $(this).val() == ''){

394                 isbreak = true;

395             }

396         })

397         if(isbreak){

398             showError("分类不能为空,请先添加分类");

399             return;

400         }

401         if ( $(this).hasClass( 'btns__upload-refresh' ) ) {

402             location.reload();

403         }

404         if ( $(this).hasClass( 'btns__upload-ing' ) ) {

405             return false;

406         }

407         var md5Ready = true;

408         $.each(md5Obj,function(index,item){

409             if(!item || item==''){

410                 md5Ready = false;

411             }

412         });

413         if(!md5Ready){

414             showError('文件尚未读取完成,请耐心等待');

415             return false;

416         }

417         if ( state === 'ready' && md5Ready ) {

418             uploader.upload();

419         } else if ( state === 'paused' ) {

420             uploader.upload();

421         } else if ( state === 'uploading' ) {

422             uploader.stop();

423         }

424     });

425     $upload.addClass( 'state-' + state );

426

427 });

 

后台(PHP)【仅分片上传相关代码】

  1     public function action_upload_file(){

  2         $file_id = R::string('file_id', 'file');

  3         $keepFileName = R::string('keepFileName', 0);

  4         $unsize_change = R::numeric('unsize_change',0);

  5         $id = R::string('id');   //插件每上传一个视频自带id

  6         $guid = R::string('guid');  //标识视频

  7         $chunks = R::numeric('chunks');  // 分片数

  8         $chunk = R::numeric('chunk');  //分片号

  9         $file_name = R::string('file_name');

 10         $file = isset($_FILES[$file_id])?$_FILES[$file_id]:'';

 11         $md5 = R::string('md5');

 12         $this->upload = new Common_Upload();

 13

 14         if(empty($guid) || empty($file_name) || empty($md5)){

 15             $this->response_msg(-1, 'guid 或 file_name 或 md5 不能为空');

 16             return;

 17         }

 18

 19         if(empty($file['name'])){

 20             $this->response_msg(-1, '请上传一个文件');

 21             return;

 22         }else{

 23             if($chunks){

 24                 $res = $this->upload->saveFile_chunks($file,$chunks, $chunk, $guid);

 25                 if(empty($res)){

 26                     $this->response_msg(-2, '分片上传失败');

 27                     return;

 28                 }

 29

 30             }else if($keepFileName){

 31                 $res = $this->upload->saveFile_nochunks($file, '', '', $keepFileName);

 32             }else{

 33                 $res = $this->upload->saveFile_nochunks($file);

 34             }

 35             if(empty($res)){

 36                 $err = $this->upload->getError();

 37                 $this->response_msg(-3, '上传文件出错!msg:'.print_r($err, true));

 38                 return;

 39             }

 40             if($unsize_change){

 41                 $size = $res['size'];

 42             }else{

 43                 $size = $this->convert_size($res['size']);

 44             }

 45

 46             //视频上传完成

 47             if($chunks && $res['last_chunk']){

 48                 $domain = Kohana::$config->load('domain');

 49                 $video_domain = $domain[RUN_MOD]['VIDEO'];

 50

 51                 if(!empty($file_name)){

 52                     $res['name'] = $file_name;

 53                 }

 54                 $video_data = array(

 55                     'video_name'=> $file_name,

 56                     'video_url'=> $video_domain."/".$res['path'],

 57                     'size'=>$res['size'],

 58                     'create_time'=> date('y-m-d H:i:s',time()),

 59                     'update_time'=> date('y-m-d H:i:s',time()),

 60                     'duration'=> $res['time'],

 61                     'md5'=>$md5

 62                 );

 63                 $video_mod = new Model_Videoinfo();

 64                 $video = $video_mod->save_video($video_data,$guid);

 65                 $res = array(

 66                     'path'=>$res['path'],

 67                     'chunks'=>$chunks,

 68                     'chunk'=>$chunk,

 69                     'size'=>$size,

 70                     'guid'=> $guid,

 71                     'video_id'=>$video[0],

 72                     'file'=>$file,

 73                     'id'=>$id

 74                 );

 75                 $this->response_msg(1,'视频上传成功',$res);

 76                 return;

 77             }

 78             //非分片上传

 79             if(!$chunks){

 80                 $domain = Kohana::$config->load('domain');

 81                 $video_domain = $domain[RUN_MOD]['VIDEO'];

 82                 if(!empty($file_name)){

 83                     $res['name'] = $file_name;

 84                 }

 85                 $video_data = array(

 86                     'video_name'=> $file_name,

 87                     'video_url'=> $video_domain."/".$res['path'],

 88                     'size'=>$res['size'],

 89                     'create_time'=> date('y-m-d H:i:s',time()),

 90                     'update_time'=> date('y-m-d H:i:s',time()),

 91                     'duration'=> $res['time'],

 92                     'md5'=>$md5

 93                 );

 94                 $video_mod = new Model_Videoinfo();

 95                 $video = $video_mod->save_video($video_data,$guid);

 96                 if(empty($video)){

 97                     $this->response_msg(-6, '视频信息保存失败');

 98                     return;

 99                 }

100                 $res = array(

101                     'path'=>$res['path'],

102                     'video_data'=>$video_data,

103                     'size'=>$size,

104                     'guid'=> $guid,

105                     'video_id'=>$video[0],

106                     'file'=>$file,

107                     'id'=>$id

108                 );

109                 $this->response_msg(1,'视频上传成功',$res);

110                 return;

111             }

112             //分片上传成功(未全部分片上传完成)

113             $res = array(

114                 'chunks'=>$chunks,

115                 'chunk'=>$chunk,

116             );

117             $this->response_msg(2, '分片上传成功',$res);

118         }

119     }

 

 

  1     /**

  2      * 保存分片文件(注意先验证文件是否合法)

  3      *

  4      * @param array $file 单个文件

  5      * @param string $attachdir 上传文件路径

  6      * @param string $upload_type 上传文件类型

  7      * @param bool $keepFileName 是否保持文件名,默认不不保持

  8      * @return bool

  9      */

 10     public function saveFile_chunks($file,$chunks, $chunk, $guid)

 11     {

 12         if(empty($guid) || empty($file) ){

 13             return false;

 14         }

 15         $file_name = (string)$guid . $chunk;

 16         //保存分片文件

 17         $file_info = $this->saveFile($file, '', '', false, $file_name,true);

 18         if ($file_info) {

 19             $cache = Cache::instance('memcache');

 20             //记录已上传的分片编号,上传顺序并不是按编号顺序进行上传

 21             $chunks_list_pre = $cache->get($guid);

 22             if(empty($chunks_list_pre)){

 23                 $strarr = array();

 24                 for($i=0;$i<$chunks;$i++){

 25                     $strarr[] = $guid.$i;

 26                 }

 27                 $cache->set($guid,$strarr,60 * 60 * 24);

 28             }

 29             $file_path = $cache->set($guid.$chunk,$file_info['path'],60 * 60 * 24);

 30

 31             $chunk_path_array= array();

 32             for($i=0;$i<$chunks;$i++){

 33                 if($cache->get($guid.$i)){

 34                     $chunk_path_array[$i] = $cache->get($guid.$i);

 35                 }

 36             }

 37             list($Y,$M,$D,$H,$I,$S) = explode('-',date("Y-m-d-H-i-s", time()));

 38             $file_info['chunks_path_count'] = count($chunk_path_array);

 39             $file_info['last_chunk'] = false;

 40             if (count($chunk_path_array) == $chunks) {

 41                 //按目录类型存储

 42                 $dirType = substr($file_info['type'], 1, strlen($file_info['type']));;

 43                 //目录类型前面加上前缀url

 44                 $dirType = $this->pre_url.$dirType;

 45                 //按年月二级存储

 46                 $month_file_path = $Y.'/'.$M;

 47                 $saveName ='upload/mp4/'.$month_file_path.'/original/'.$guid.$file_info['type'];

 48                 $join_file_name =$this->attachDIR.$saveName;

 49                 if(!is_dir($this->attachDIR.'upload/mp4/'.$month_file_path.'/original/')){

 50                     mkdir($this->attachDIR.'upload/mp4/'.$month_file_path.'/original/',0755,true);

 51                 }

 52                 if(! file_exists($join_file_name)){

 53                     $fp = fopen($join_file_name, "ab");

 54                     //合并过程中对文件加锁,防止同时操作而出错

 55                     if (flock($fp,LOCK_EX)){

 56                         for ($i = 0; $i < $chunks; $i++) {

 57                                 $tmp_file = $this->attachDIR . $chunk_path_array[$i];

 58                                 $handle = fopen($tmp_file, "rb");

 59                                 fwrite($fp, fread($handle, filesize($tmp_file)));

 60                                 fclose($handle);

 61                                 unset($handle);

 62                                 unlink($tmp_file);//合并完毕的文件就删除

 63                         }//组装分片

 64                         $cache->delete($guid);

 65                         for($i=0;$i<$chunks;$i++){

 66                             $cache->delete($guid.$i);

 67                         }

 68                         $time = $this->getTime($join_file_name,$file_info['type']);

 69                         $file_info['time'] = $time;

 70                         $file_info['path'] = $saveName;

 71                         $file_info['size'] = filesize($join_file_name);

 72                         $file_info['last_chunk'] = true;

 73

 74                         $model_mod = new Model_Base();

 75                         $model_mod->disconnect();

 76                         $pid = pcntl_fork();

 77                         //父进程和子进程都会执行下面代码

 78                         if ($pid == -1) {

 79                             //错误处理:创建子进程失败时返回-1.

 80                             die('could not fork');

 81                         } else if ($pid) {

 82                             $model_mod->connect();

 83                             //对上传完成的视频进行排队转码

 84                             $this->thread($join_file_name,$file_info['type'],$guid);

 85                             //父进程会得到子进程号,所以这里是父进程执行的逻辑

 86                             pcntl_wait($status); //等待子进程中断,防止子进程成为僵尸进程。

 87                         } else {

 88                             return $file_info;

 89                             //子进程得到的$pid为0, 所以这里是子进程执行的逻辑。

 90                         }

 91

 92                     }

 93                 }

 94

 95             }

 96             return $file_info;

 97         } else {

 98                 $this->error[] = '分片上传失败';

 99                 return false;

100         }

101             /*}}}*/

102         }

 

1,实现了分片上传;

2,同时在上传前检查视频md5 是否在库,如已存在可实现“秒传” 功能,即直接复制数据信息,指向同一个文件,不必再上传;

3,可实现断点续传,上传过程中中断;之前上传的分片已保留在服务器,只需重新上传尚未上传的分片即可;

参考文章:http://blog.ncmem.com/wordpress/2019/08/12/java-http%E5%A4%A7%E6%96%87%E4%BB%B6%E6%96%AD%E7%82%B9%E7%BB%AD%E4%BC%A0%E4%B8%8A%E4%BC%A0/

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. PYTHON汇总excel超时名单

    每月需汇总审批超时人员次数名单,文档为从数据库导出。由于审批时间在文本中,需对文本进行正则截取、格式化拆分,并判断审批时间是否超时并生成超时列表,再写入工作簿。最后对超时名单做汇总求和。由于存在假日调休,对假日、调休,写死在代码中缺乏灵活性。待改正#!/usr/b…...

    2024/5/7 3:38:29
  2. 第二章 第8节Java语言基础(原码反码补码的练习)

    JavaSE视频课程完整版本课程讲师拥有15年BAT大型项目经验,多次参与重大项目研发工作,拥有多年实战技术积累,从0入门讲解,由浅到深的教学,让每一位学员都能学以致用!菜鸟学院9.90去订阅第二章 第8节Java语言基础(原码反码补码的练习)查看专栏详情立即解锁全部专栏...

    2024/5/8 14:28:34
  3. 第二章 第9节Java语言基础(变量的概述及格式)

    JavaSE视频课程完整版本课程讲师拥有15年BAT大型项目经验,多次参与重大项目研发工作,拥有多年实战技术积累,从0入门讲解,由浅到深的教学,让每一位学员都能学以致用!菜鸟学院9.90去订阅第二章 第9节Java语言基础(变量的概述及格式)查看专栏详情立即解锁全部专栏...

    2024/5/8 16:07:02
  4. 【每日一题】滴滴原题:数组重组

    描述 给定一个数组 里面只有0跟1 然后把如果有0那么把0 变成2个,顺序不变,多出的位数 直接舍弃 例子 [1,0,1]=>[1,0,0] [001010]=>[000010] 时间复杂度 O(n) 空间复杂度O(n) 思路 利用新开一个数组,进行扫描遇到1,则填入1,遇到0则填入00。 代码 #include<stdio.h&…...

    2024/5/7 3:38:17
  5. python//Jan.18th,2020//异常

    Jan.18th,2020##异常#处理ZeroDivisionError异常 ##trackback 引用,引用功能 #print(5/0)#使用try_except代码块 #try: # print(5/0) #except ZeroDivisionError: # print("You cant divide by zero!")#使用异常避免崩溃 #print("Give me two number,a…...

    2024/5/8 16:04:15
  6. 第二章 第10节Java语言基础(数据类型的概述和分类)

    JavaSE视频课程完整版本课程讲师拥有15年BAT大型项目经验,多次参与重大项目研发工作,拥有多年实战技术积累,从0入门讲解,由浅到深的教学,让每一位学员都能学以致用!菜鸟学院9.90去订阅第二章 第10节Java语言基础(数据类型的概述和分类)查看专栏详情立即解锁全部专栏...

    2024/5/8 16:39:07
  7. C++编程之美-数字之魅(代码清单2-18)

    代码清单2-18 int Fibonacci(int n) {if(n <= 0){return 0;}else if (n == 1){return 1;}else{return Fibonacci(n - 1) + Fibonacci(n - 2);} }...

    2024/5/7 3:38:05
  8. 数列分块模板

    数列分块入门1 #include <cstdio> #include <iostream> #include <cstring> #include <algorithm> #include <string> #include <set> #include <cmath> #include <map> #include <vector> using namespace std; typede…...

    2024/5/7 3:38:04
  9. 解决 xml代码不能自动提示的问题

    https://blog.csdn.net/Steven_0324/article/details/88013242...

    2024/5/7 3:37:57
  10. 《python无师自通》第十五章 综合练习

    战争(存在问题)from random import shuffle#卡牌class Card:suits = ["spades",#表示花色"hearts","diamonds","clubs"]values = [None,None,"2","3",#两个空值是为了数字2对应索引2"4","5"…...

    2024/5/8 14:29:30
  11. C# Producer Consumer (生产者消费者模式)demo

    第一套代码将producer Consumer的逻辑写到from类里了,方便在demo的显示界面动态显示模拟生产和消费的过程。第二套代码将producer Consumer的逻辑单独写到一个类中,使用委托的方法在from中回显生产消费的过程。Demo中均以3个线程作为消费者,1个线程作为生产者为例。 由于是C…...

    2024/5/7 3:37:49
  12. 第二章 第11节Java语言基础(定义不同数据类型的变量)

    JavaSE视频课程完整版本课程讲师拥有15年BAT大型项目经验,多次参与重大项目研发工作,拥有多年实战技术积累,从0入门讲解,由浅到深的教学,让每一位学员都能学以致用!菜鸟学院9.90去订阅第二章 第11节Java语言基础(定义不同数据类型的变量)查看专栏详情立即解锁全部专栏...

    2024/5/7 3:37:45
  13. Mybatis 中经典的 9 种设计模式

    虽然我们都知道有23个设计模式,但是大多停留在概念层面,真实开发中很少遇到。Mybatis源码中使用了大量的设计模式,阅读源码并观察设计模式在其中的应用,能够更深入的理解设计模式。 Mybatis至少遇到了以下的设计模式的使用: 1、Builder模式,例如SqlSessionFactoryBuilder…...

    2024/5/6 8:10:57
  14. 剑指Offer对答如流系列 - 机器人的运动范围

    文章目录面试题12:机器人的运动范围一、题目描述二、问题分析三、问题解答 面试题12:机器人的运动范围 一、题目描述 地上有一个m行n列的方格。一个机器人从坐标(0, 0)的格子开始移动,它每一次可以向左、右、上、下移动一格,但不能进入行坐标和列坐标的数位之和大于k的格子…...

    2024/5/7 3:37:41
  15. PK3 烧录

    PK3烧录可以调用烧录和读取控制信息:擦除操作检测是否为空IC烧录IC指令读取IC数据指令...

    2024/5/7 3:37:37
  16. 交换机配置第三讲(交换机的基本介绍)

    交换机端口的三种链路类型以太网端口有三种链路类型:access、trunk、hybird1.交换机的端口0/0/1 含义。第x台设备、第y板卡、第z端口。2.端口类型一共有三种(这个很重要需要记住)access,trunk,hybird。access: port只属于一个vlan,(我是这样记的)通常主机连接交换机用的是…...

    2024/5/7 3:37:33
  17. Visual Studio下使用jQuery的10个技巧

    【51CTO经典译文】广泛流行的jQuery是一个开源的,跨浏览器和兼容CSS 3的JavaScript库,你可以用它简化你的JavaScript编码任务和操作(添加,编辑和删除)HTML内容中的DOM元素,本文介绍10个在Visual Studio下使用jQuery的10个有用的技巧,希望对你有所帮助。你需要准备些什么…...

    2024/5/7 3:37:29
  18. C++编程之美-数字之魅(代码清单2-17)

    代码清单2-17 // 初始化for(i = 0; i < N; i++)BigInt[i].clear();BigInt[1].push_back(0);int NoUpdate = 0; for(i=1,j=10%N; ; i++,j=(j*10)%N){bool flag = false;if(BigInt[j].size() == 0){flag = true;// BigInt[j] = 10^i, (10^i % N = j)BigInt[j].clear();BigInt[…...

    2024/5/7 3:37:25
  19. Flowable-UI (四) Flowable 流程、表单部署(发布应用)

    Flowable 流程、表单部署(发布应用) 一、前提创建流程Flowable-UI (二) Flowable 创建报销流程例子 创建一个表单Flowable-UI (三) Flowable流程中加入 form 表单二、创建应用程序点击“应用程序”菜单 点击“创建应用程序”按钮 创建应用程序,填写应用的名称、 key 及描述,…...

    2024/5/7 3:37:21
  20. 慢慢了解webpack

    内容概述 webpack(一):什么是webpack? webpack(二):webpack安装 webpack(三):webpack起步 webpack(四):webpack配置 webpack(五):loader的使用 webpack中配置Vue plugin的使用 搭建本地服务器 参考文档...

    2024/5/7 3:37:17

最新文章

  1. LINUX 入门 4

    LINUX 入门 4 day6 7 20240429 20240504 耗时&#xff1a;240min 课程链接地址 第4章 LINUX环境编程——实现线程池 C基础 第3节 #define里面的行不能乱空行&#xff0c;要换行就打\ typedef 是 C 和 C 中的一个关键字&#xff0c;用于为已有的数据类型定义一个新的名字。…...

    2024/5/8 18:48:43
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/5/7 10:36:02
  3. 【精选】发布应用到应用商店的基本介绍

    摘要 本文旨在介绍如何在各大应用商店发布应用&#xff0c;包括市场选择、准备材料、上架步骤以及常见被拒原因及解决方法。通过详细的步骤和经验分享&#xff0c;帮助开发者顺利将应用推向市场。 引言 随着移动应用市场的不断发展&#xff0c;越来越多的开发者希望将他们的…...

    2024/5/6 15:12:35
  4. Go语言map、slice、channel底层实现(go面试)

    slice 切片是一个引用类型&#xff0c;其底层实现是一个结构体&#xff0c;包含以下字段&#xff1a; ptr&#xff1a;一个指向底层数组的指针&#xff0c;指针指向数组的第一个元素。 len&#xff1a;切片当前包含的元素数量。 cap&#xff1a;切片的容量&#xff0c;即底层…...

    2024/5/5 1:45:06
  5. 图解深度神经网络的架构

    图解深度神经网络的架构 基线模型 AlexNet 是突破性的架构&#xff0c;它使卷积网络&#xff08;CNN&#xff09;成为处理大型图像分类任务的主要机器学习算法。介绍 AlexNet 的论文呈现了一张很好的图&#xff0c;但是好像还缺点什么…… AlexNet 架构图示&#xff08;图源&…...

    2024/5/6 16:01:00
  6. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/5/8 6:01:22
  7. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/5/7 9:45:25
  8. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/5/4 23:54:56
  9. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/5/7 14:25:14
  10. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/5/4 23:54:56
  11. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/5/4 23:55:05
  12. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/5/4 23:54:56
  13. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/5/7 11:36:39
  14. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/5/4 23:54:56
  15. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/5/6 1:40:42
  16. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/5/4 23:54:56
  17. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/5/4 23:55:17
  18. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/5/7 9:26:26
  19. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/5/4 23:54:56
  20. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/5/4 23:55:06
  21. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/5/5 8:13:33
  22. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/5/4 23:55:16
  23. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/5/4 23:54:58
  24. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/5/6 21:42:42
  25. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/5/4 23:54:56
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  27. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57