非同步上傳
A. 同步傳輸和非同步傳輸網路上的概念是什麼
這個問題屬於數據傳輸的一種.最簡單的例子就是比方說要把東西(data)從A點到B點互相輸送.同步傳輸可以"同時"兩點間輸送(A-->B,A<--B).非同步傳輸只能先等完成一個方向(A-->B)的輸送,再進行反方向的輸送(B-->A).
B. 非同步傳輸的基本概念
非同步傳輸是數據傳輸的一種方式。由於數據一般是一位接一位串列傳輸的,例如在傳送一串字元信息時,每個字元代碼由7位二進制位組成。但在一串二進制位中,每個7位又從哪一個二進制位開始算起呢?非同步傳輸時,在傳送每個數據字元之前,先發送一個叫做開始位的二進制位。當接收端收到這一信號時,就知道相繼送來7位二進制位是一個字元數據。在這以後,接著再給出1位或2位二進制位,稱做結束位。接收端收到結束位後,表示一個數據字元傳送結束。這樣,在非同步傳輸時,每個字元是分別同步的,即字元中的每個二進制位是同步的,但字元與字元之間的間隙長度是不固定的。
非同步傳輸,英文名AsynchronousTransfer Mode,ATM,是實現B-ISDN的一項技術基礎,是建立在電路交換和分組交換的基礎上的快速分組交換技術。ATM的主要特點是面向連接;採用小的、固定長度的單元(53位元組);取消鏈路的差錯控制和流量控制等,這些措施提高了傳輸效率。ATM的突出優點是可以為每個虛連接提供相應的服務質量(QOS),可以有效地支持視、音頻多媒體傳輸,包括語音、視頻和數據等;另外,ATM可以實現區域網和廣域網的平滑無縫連接。
非同步傳輸一般以字元為單位,不論所採用的字元代碼長度為多少位,在發送每一字元代碼時,前面均加上一個「起」信號,其長度規定為1個碼元,極性為「0」,即空號的極性;字元代碼後面均加上一個「止」信號,其長度為1或者2個碼元,極性皆為「1」,即與信號極性相同,加上起、止信號的作用就是為了能區分串列傳輸的「字元」,也就是實現了串列傳輸收、發雙方碼組或字元的同步。
C. 求一段JS或Jquery非同步上傳圖片的代碼
圖片和文件等流媒體 上傳都是靠from表單的提交。
你可以設置一個隱藏的from表單
裡面有個<input id='file' type='file'>
選擇玩圖片之後賦值給file
然後用jquery from表單提交即可
<formid="form"runat="server"enctype="multipart/form-data">
<inputid='file'type='file'>
</from>
$.ajax({
url:'XXXX',//上傳後台路徑
data:$('#form').serialize(),
type:"POST",
success:function(){
}
});
D. 在javascript中如何實現非同步圖片上傳
var formData = new FormData();
//html: <input type="file" id="img"/>
formData.append('shopImg', $('#img')[0].files[0]);
$.ajax({
url: controllerUrl,
data: formData,
success: function(){
$.toast('提交成功!');
}
});
E. 如何實現一次選擇多個文件上傳,而且非同步上傳
swfupload插件
<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml">
<metahttp-equiv='Content-Type'content='text/html;charset=utf-8'/>
<title>Fileupload</title>
<linkrel="Stylesheet"href="js/Plug-in/jquery.uploadify/uploadify.css"/>
<scripttype="text/javascript"src="js/Plug-in/jquery.uploadify/jquery-1.3.2.min.js"></script>
<scripttype="text/javascript"src="js/Plug-in/jquery.uploadify/swfobject.js"></script>
<scripttype="text/javascript"src="js/Plug-in/jquery.uploadify/jquery.uploadify.v2.1.0.min.js"></script>
<scripttype="text/javascript">
$(document).ready(function(){
$("#uploadify").uploadify({
'uploader':'js/Plug-in/jquery.uploadify/uploadify.swf',
'script':'uploadify.php',
'cancelImg':'js/Plug-in/jquery.uploadify/cancel.png',
'folder':'uploadfile',
'queueID':'fileQueue',
'auto':false,
'multi':true,
});
});
</script>
</head>
<body>
MAX:20M
</BR>
<inputtype="file"name="uploadify"id="uploadify"/>
<ahref="javascript:$('#uploadify').uploadifyUpload()">Upload</a>|<ahref="javascript:$('#uploadify').uploadifyClearQueue()">cancel</a>
<divid="fileQueue"></div>
</body>
</html>
#uploadify.php
<?php
if(!empty($_FILES)){
$tempFile=$_FILES['Filedata']['tmp_name'];
$targetPath=$_SERVER['DOCUMENT_ROOT'].$_REQUEST['folder'].'/';
$targetFile=str_replace('//','/',$targetPath).$_FILES['Filedata']['name'];
$targetFile=iconv("utf-8","gbk",$targetFile);
move_uploaded_file($tempFile,$targetFile);
echo"1";
}
?>
F. 什麼是同步傳輸,什麼事非同步傳輸它們有什麼區別
通俗的講就是:同步:你若現在要做一頓飯。流程是:買菜,煮飯,洗菜,煮菜。假設有這些個流程。同步就是你要按著這個順序做下去。先買菜,再煮飯,煮完飯後再洗菜,也就是說在煮飯的時候,飯還沒熟,不能去做其他事。要等飯孰了,關火了再去洗菜。讓你有一種站在那裡看著飯煮的感覺,知道嗎?非同步:那就不一樣了,雖然你做這頓飯也是按照這幾個流程去做。但是有一點不一樣就是:你在煮飯的時候,開火讓它在那裡煮就可以了,你開完火後就離開,去洗菜,煮菜等,不用等到飯熟了再去洗菜。然後呢,飯熟了。飯鍋有提示說飯熟了你就叫一個人去處理飯熟的結果(關火等),你不審洗你的菜煮你的菜,這就是非同步。夠通俗嗎?哈哈
G. 什麼是同步傳輸什麼是非同步傳輸
概念如下:
同步傳輸該方式是在一塊數據的前面加入1個或2 個以上的同步字元SYN。SYN 字元是從ASCII 碼中精選出來供通信用的同步控制字元。同步字元後面的數據字元不需任何附加位,同步字元表示字元傳送的開始,發送端和接收端應先約定同步字元的個數。
非同步傳輸(ATM)是每一個字元獨立形成一個幀進行傳輸,一個連續的字元串同樣被封裝成連續的獨立幀進行傳輸,各個字元間的間隔可以是任意的,所以這種傳輸方式稱為非同步傳輸。
傳輸模式
同步傳輸是以同定的時鍾節拍來發送數據信號的。因此,在一個串列的數據流中,各信號碼元之間的相對位置都是固定的,接收方為了從收到的數據流中正確地區分出一個個信號碼元,首先必須建立准確的時鍾信號。
這是同步傳輸比非同步傳輸復雜的點。在同步傳輸中,數據的發送一般以組(或稱幀,或稱包)為單位,一組數據包含多個字元的代碼或多個獨立的比特位,在組的開頭和結束需加上預先規定的起始序列和終止序列作為標志。
起始序列和終止序列的形式隨採用的傳輸控制規程而異。面向位流的通信規程即位同步方式有HDLC(High Level Data Link Contr01)規程。面向字元的通信規程,即按字元同步方式有BSC二進制同步通信規程。
非同步傳輸模式(Asynchronous Transfer Mode)是一種信元交換和多路復用技術。ATM採用信元(Cell)作為傳輸單位,信元具有固定長度,總共53位元組,前5位元組是信頭(Header),其餘48位元組是數據段。信頭中有信元去向的邏輯地址、優先順序、信頭差錯控制、流量控制等信息。
數據段中裝入被分解成數據塊的各種不同業務的用戶信息或其他管理信息,並透明地穿過網路。
H. 不要組件插件怎麼非同步上傳文件,要求選擇文件後直接上傳(不點發送提
結合HTML5,
<formenctype="multipart/form-data">
<inputid="file"name="file"type="file"/>
<inputtype="button"value="Upload"/>
</form>
<progress></progress>
$('#file').change(function(){
varformData=newFormData($('form')[0]);
$.ajax({
url:'upload.php',//接收頁面
type:'POST',
xhr:function(){//XHR事件
myXhr=$.ajaxSettings.xhr();
if(myXhr.upload){//檢測是否有此方法屬性
myXhr.upload.addEventListener('progress',progressHandlingFunction,false);//設置進度
}
returnmyXhr;
},
//Ajax事件
beforeSend:beforeSendHandler,
success:completeHandler,
error:errorHandler,
//Form數據
data:formData,
cache:false,
contentType:false,
processData:false
});
});
I. 同步傳輸和非同步傳輸有什麼區別
在計算機網路中,定時的因素稱為位同步。同步是要接收方按照發送方發送的每個位的起止時刻和速率來接收數據,否則會產生誤差。通常可以採用同步或非同步的傳輸方式對位進行同步處理。
同步傳輸方式中發送方和接收方的時鍾是統一的、字元與字元間的傳輸是同步無間隔的。
非同步傳輸方式並不要求發送方和接收方的時鍾完全一樣,字元與字元間的傳輸是非同步的。
非同步傳輸是面向字元的傳輸,而同步傳輸是面向比特的傳輸。
非同步傳輸的單位是字元而同步傳輸的單位是楨。
非同步傳輸通過字元起止的開始和停止碼抓住再同步的機會,而同步傳輸則是以數據中抽取同步信息。
非同步傳輸對時序的要求較低,同步傳輸往往通過特定的時鍾線路協調時序。
非同步傳輸相對於同步傳輸效率較低。
(9)非同步上傳擴展閱讀
1,同步傳輸是以同定的時鍾節拍來發送數據信號的。因此,在一個串列的數據流中,各信號碼元之間的相對位置都是固定的,接收方為了從收到的數據流中正確地區分出一個個信號碼元,首先必須建立准確的時鍾信號。這是同步傳輸比非同步傳輸復雜的點。
2,在同步傳輸中,數據的發送一般以組(或稱幀,或稱包)為單位,一組數據包含多個字元的代碼或多個獨立的比特位,在組的開頭和結束需加上預先規定的起始序列和終止序列作為標志。
3,非同步傳輸(Asynchronous Transmission): 非同步傳輸將比特分成小組進行傳送,小組可以是8位的1個字元或更長。發送方可以在任何時刻發送這些比特組,而接收方從不知道它們會在什麼時候到達。
4,一個常見的例子是計算機鍵盤與主機的通信。按下一個字母鍵、數字鍵或特殊字元鍵,就發送一個8比特位的ASCII代碼。鍵盤可以在任何時刻發送代碼,這取決於用戶的輸入速度,內部的硬體必須能夠在任何時刻接收一個鍵入的字元。
J. Java中如何圖片非同步上傳
在java中要實現非同步上傳要提前做好准備,對於文件上傳,瀏覽器在上傳的過程中是將文件以流的形式提交到伺服器端的,如果直接使用Servlet獲取上傳文件的輸入流然後再解析裡面的請求參數是比較麻煩,所以一般選擇採用apache的開源工具common-fileupload這個文件上傳組件。
這個common-fileupload上傳組件的jar包可以去apache官網上面下載,也可以在struts的lib文件夾下面找到,struts上傳的功能就是基於這個實現的。
common-fileupload是依賴於common-io這個包的,所以還需要下載這個包。剩下的就是js文件的導入了,我導入了以下文件:
<script type="text/javascript" src="lib/Js/jquery.js"></script>
<script ltype="text/javascript" src="/js/ajaxfileupload.js"></script>
在頁面中的寫法:
div class="controls"><span class="btn green fileinput-button"><i class="icon-plus icon-white"></i>
<span>上傳照片</span>
<input id="fileToUpload" name="myfiles" type="file" onchange="upload()" title="上傳" /></span>
</div>function upload(){
$.ajaxFileUpload
(
{
url:'<%=basePath%>sysperson/uploadpic',
secureuri:false,
fileElementId:'fileToUpload',
dataType: 'text',
success: function (data, status)
{
document.all.mypic.src="<%=basePath%>uploads/" + data;
document.all.picpath.value = data;
}, error : function(data, status, e) {
alert(e);
}
});
}