我正面临以下问题,似乎无法解决。 我们正在使用Codeigniter 3开发一个站点。 要将文件上传到网站,请使用Dropzone.js
我想实现以下目标: 在上载期间,用户有机会取消上载过程。 addRemoveLinks:是
现在,我同时将文件参数(id,名称,大小等)保存到数据库中。 单击取消上传按钮后,上传将停止,但是到那时,视频参数已保存到数据库中。 在网站上,视频缩略图是根据数据库行加载的,因此取消上传时,我想从db中删除关联的行。
问题是,仅当我在Chrome开发人员工具中设置调试点时,我的代码才能工作,但是代码的处理时间仍然很长。
没有调试点,不会删除数据库行。
这是我footer.php中的代码
<!-- Bootstrap core JavaScript -->
<script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
<script src="https://code.jquery.com/ui/1.12.0/jquery-ui.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.12.9/umd/popper.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/js/bootstrap.min.js"></script>
<!-- JS file -->
<script src="<?php echo asset_url(); ?>js/autocomplete/jquery.easy-autocomplete.min.js"></script>
<!-- CSS file -->
<link rel="stylesheet" href="<?php echo asset_url(); ?>js/autocomplete/easy-autocomplete.css">
<!-- Tables -->
<script type="text/javascript" src="https://cdn.datatables.net/v/bs4/dt-1.10.18/datatables.min.js"></script>
<!-- Upload -->
<script src="<?php echo asset_url(); ?>js/dropzone.js"></script>
<script>
Dropzone.options.dropzonejsform = {
maxFilesize: 20000,
addRemoveLinks: true,
dictCancelUpload: "<p style =\"font-size:115%; display:block\">Cancel upload<p>",
dictRemoveFile: "",
dictDefaultMessage: "<h3>Drag'n'drop files <br> or <button type='button' class='btn btn-outline-success' value='Upload'>click here</button> to upload</h3>",
init: function() {
this.on("removedfile", function(file) {
var name = file.name;
$.ajax({
cache: false,
url: './delete2/' + name,
type: "GET",
success: function(html) {
location.reload();
}
});
});
this.on("queuecomplete", function() {
location.reload();
});
}
}
</script>
由于某种原因,没有$ ajax调试点,该代码不会从db中删除。 有什么建议吗?
编辑: @Alex,这是上传和删除功能
public function delete_video2($video_name){
$this->db->where('video_name', $video_name);
$this->db->delete('videos');
}
// Add Video
public function add_video()
{
$this->load->helper('url');
//allowed file types
$arr_file_types = ['video/mp4', 'video/avi', 'video/mov', 'video/3gp', 'video/mpeg'];
// Target Path
$target_dir = "./assets/upload/";
// Assigining Random Name
$File_Name = $_FILES["file"]["name"]; // Get file name
$File_Size = $_FILES["file"]["size"]; // Get file name
$File_Ext = substr($File_Name, strrpos($File_Name, '.')); // Get file extention
$Random_Number = rand(0, 9999999999); // Random number to be added to name.
$NewFileName = $Random_Number.$File_Ext; // New file name
// Uploading name to dataase
move_uploaded_file($_FILES['file']['tmp_name'], $target_dir.$NewFileName);
// echo "true";
// die();
$user = $this->ion_auth->user()->row();
$id = $user->id;
$data = array(
'reference_id' => $File_Ext,
'user_id' => $id,
'video_name' => $File_Name,
'video_url' => $NewFileName,
'video_size' => $File_Size,
);
return $this->db->insert('videos', $data);
}
视图的其余部分
<!-- Button to Open the Modal -->
<button type="button" class="btn btn-outline-upload" style="font-size:20px;" data-toggle="modal" data-target="#myModal">
<i class="fa fa-plus-square"></i> Upload New Video
</button>
<!-- Upload Modal -->
<div class="modal" id="myModal">
<div class="modal-dialog-index" style="max-width:350px">
<div class="modal-content">
<!--Dropzone upload form-->
<?php $attributes = array('id' => 'dropzonejsform', 'class' => 'dropzone', 'enctype' => 'multipart/form-data' ); ?>
<?php echo form_open("upload", $attributes);?>
<?php echo form_close();?>
</div>
</div>
</div>
答案 0 :(得分:0)
您的删除请求可能是在其他处理(例如文件上传)以某种方式阻止它的时候发生的,并且通过添加断点,您可以将ajax调用延迟到该处理完成之后-这就是为什么您仅看到它起作用的原因。
在发出删除请求之前,请确保数据库已完成写入等操作,并且处于删除条目的状态。