欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

將音頻文件轉(zhuǎn)二進制分包存儲到Redis的實現(xiàn)方法(奇淫技巧操作)

 更新時間:2020年07月24日 08:39:36   作者:帥爆了的吳彥祖  
這篇文章主要介紹了將音頻文件轉(zhuǎn)二進制分包存儲到Redis的實現(xiàn)方法(奇淫技巧操作),本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

功能需求:

一、獲取本地音頻文件,進行解析成二進制數(shù)據(jù)音頻流

二、將音頻流轉(zhuǎn)化成byte[]數(shù)組,按指定大小字節(jié)數(shù)進行分包

三、將音頻流分成若干個包,以List列表形式緩存到redis數(shù)據(jù)庫中

四、從redis數(shù)據(jù)庫中獲取數(shù)據(jù),轉(zhuǎn)換成音頻流輸出到瀏覽器播放、實現(xiàn)音頻下載功能

程序如下:

1.在SpringBootpom.xml文件中添加Redis依賴

<!--Redis依賴-->
 <dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-data-redis</artifactId>
 </dependency>

2.在SpringBoot配置文件中添加以下配置

# 服務(wù)端口
server:
 port: 8080

spring:
#reids配置
redis:
 host: 127.0.0.1 # Redis服務(wù)器地址
 database: 1 # Redis數(shù)據(jù)庫索引(默認為0)
 port: 6379 # Redis服務(wù)器連接端口
 password: # Redis服務(wù)器連接密碼(默認為空)
 jedis:
 pool:
 max-active: 8 # 連接池最大連接數(shù)(使用負值表示沒有限制)
 max-wait: -1ms # 連接池最大阻塞等待時間(使用負值表示沒有限制)
 max-idle: 8 # 連接池中的最大空閑連接
 min-idle: 0 # 連接池中的最小空閑連接
 timeout: 3000ms # 連接超時時間(毫秒)

3.創(chuàng)建RedisTemplate對象操作redisRedisTemplate介紹:

說的通俗一點…為了讓Spring框架體系能夠更加方便的接入Redis的功能,RedisTemplate其實就是Spring框架對Jedis的封裝…是 spring-data-redis中使用redis的模版。

/**
 * 創(chuàng)建redisTemplate對象操作redis
 */

 @Resource
 private RedisTemplate<String,Object> redisTemplate;

4.主業(yè)務(wù)數(shù)據(jù)處理讀取音頻文件進行轉(zhuǎn)換存儲

通過FileInputStream對象把音頻文件轉(zhuǎn)換成byte[]數(shù)組,進行分包,把分好包的字節(jié)數(shù)據(jù)添加到List集合中,在調(diào)用RedisTemplate對象的opsForList().rightPushAll方法批量添加參數(shù)List元素,以Redis的列表數(shù)據(jù)格式存儲。

/**
 * 獲取文件將文件轉(zhuǎn)換成byte[]數(shù)組,進行分包存儲到redis
 */
 @RequestMapping("/setAudio")
 @ResponseBody
 public Object getsty() throws Exception {
 File file = new File("E:/zmj-3011-32779/12121.mp3");
 FileInputStream inputFile = new FileInputStream(file);
 byte[] buffer = new byte[(int) (file.length() * 1)];
 inputFile.read(buffer);//文件解析把字節(jié)數(shù)添加到buffer[]中
 inputFile.close();

 int viceLength = 180; //每個字節(jié)包大小
 int viceNumber = (int) Math.ceil(buffer.length /(double) viceLength);//存多少個包
 int from, to;
 List listrk = new ArrayList();
 for (int i=0;i<viceNumber;i++){ //將完整音頻buffer[]進行循環(huán)拆分
  ioentity ioe=new ioentity();
  from=(int) (i*viceLength);
  to=(int)(from+viceLength);
  if(to>buffer.length)
  to=buffer.length;
  listrk.add(Arrays.copyOfRange(buffer,from,to));//按字節(jié)范圍拷貝生成新數(shù)組,添加到List列表中
 }
 redisTemplate.opsForList().rightPushAll("Audio", listrk);//redisTemplate的批量添加,以List列表形式進行存儲
 return "redis入庫成功!";
 }

redis客戶端存儲結(jié)果:

可以看出只存儲了一個key,value是以list列表形式存儲,音頻文件以180個字節(jié)數(shù)組進行存儲,一共存儲了2634個。此處沒有設(shè)緩存時間,所以不會超時。

6.從Redis數(shù)據(jù)庫緩存中獲取音頻數(shù)據(jù)進行解析

通過Redis對象的redisTemplate.opsForList().range方法獲取緩存的value,通過list集合接收進行遍歷,進行合并生成一個新的byte數(shù)組,在通過OutputStream對象輸出byte數(shù)組,瀏覽器自動解析二進制音頻流文件。

/**
 * 從redis中分包取值進行byte[]數(shù)組合并解析音頻
 */
 @RequestMapping("/getkeyAudio")
 public Object getKey(HttpServletResponse response) throws Exception{
 OutputStream os = response.getOutputStream();
 List list =redisTemplate.opsForList().range("Audio", 0, -1); //通過key獲取指定區(qū)間的值,List方式存儲用List集合去接收

 //合并音頻
 List<byte[]> blist = list;
 int lengthTotal = 0;
 for (byte[] item : blist) {
  lengthTotal += item.length;
 }
 byte[] totalByte = new byte[lengthTotal];
 int begin = 0;
 for (byte[] item : blist) {
  //System.arraycopy(原數(shù)組, 原數(shù)組起始位置, 目標數(shù)組, 目標數(shù)組起始位置, 復(fù)制長度);
  System.arraycopy(item, 0, totalByte, begin, item.length);
  begin += item.length;
 }
 os.write(totalByte);//通過OutputStream對象輸出合并后的數(shù)組

 return ""; //OutputStream對象輸出流,直接返回為空,瀏覽器自動會為我們解析音頻流
 }

第一種解析方法:

瀏覽器發(fā)起請求得到音頻二進制流,瀏覽器解析自動生成一個播放器播放該音頻及附加下載功能。

第二種解析方法:

在HTML頁面中定義Audio標簽,創(chuàng)建XMLHttpRequest對象發(fā)起請求,通過Audio標簽進行解析。

<audio id="sound" width="200" controls="controls"></audio>

<script>
 $(document).ready(function(){
 agf();
 });

 function agf() {
 //創(chuàng)建XMLHttpRequest對象
 var xhr = new XMLHttpRequest();
 //配置請求方式、請求地址以及是否同步
 xhr.open('POST', '/getkey', true);
 xhr.setRequestHeader("Content-type","application/x-www-form-urlencoded");
 //設(shè)置請求結(jié)果類型為blob
 xhr.responseType = 'blob';
 //請求成功回調(diào)函數(shù)
 xhr.onload = function(e) {
 if (this.status == 200) {//請求成功
  //獲取blob對象
  var blob = this.response;
  //獲取blob對象地址,并把值賦給容器
  $("#sound").attr("src", URL.createObjectURL(blob));
 }
 };
 xhr.send(); 
 }
</script>

總結(jié):

到此這篇關(guān)于將音頻文件轉(zhuǎn)二進制分包存儲到Redis的實現(xiàn)方法(奇淫技巧操作)的文章就介紹到這了,更多相關(guān)音頻文件轉(zhuǎn)二進制分包存儲到Redis內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Redis保證數(shù)據(jù)不丟失的兩種方法

    Redis保證數(shù)據(jù)不丟失的兩種方法

    Redis 實現(xiàn)數(shù)據(jù)不丟失的關(guān)鍵在于使用了多種持久化機制,以確保數(shù)據(jù)在內(nèi)存和磁盤之間的持久性,本文給大家介紹了Redis保證數(shù)據(jù)不丟失的兩種方法,持久化和集群運行,我們分別來看它們兩的具體實現(xiàn)細節(jié),感興趣的同學(xué)跟著小編一起來看看吧
    2023-11-11
  • Redis基于Bitmap實現(xiàn)用戶簽到功能

    Redis基于Bitmap實現(xiàn)用戶簽到功能

    很多應(yīng)用上都有用戶簽到的功能,尤其是配合積分系統(tǒng)一起使用。本文主要介紹了Redis基于Bitmap實現(xiàn)用戶簽到功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • 基于Redis的List實現(xiàn)特價商品列表功能

    基于Redis的List實現(xiàn)特價商品列表功能

    本文通過場景分析給大家介紹了基于Redis的List實現(xiàn)特價商品列表,本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2021-08-08
  • redis?zset實現(xiàn)滑動窗口限流的代碼

    redis?zset實現(xiàn)滑動窗口限流的代碼

    這篇文章主要介紹了redis?zset實現(xiàn)滑動窗口限流,滑動窗口算法思想就是記錄一個滑動的時間窗口內(nèi)的操作次數(shù),操作次數(shù)超過閾值則進行限流,本文通過實例代碼給大家詳細介紹,需要的朋友參考下吧
    2022-03-03
  • Redis三種集群搭建配置(主從集群、哨兵集群、分片集群)

    Redis三種集群搭建配置(主從集群、哨兵集群、分片集群)

    本文主要介紹了Redis三種集群搭建配置,包括主從集群、哨兵集群、分片集群,具有一定的參考價值,感興趣的可以了解一下
    2024-03-03
  • redis過期監(jiān)聽機制方式

    redis過期監(jiān)聽機制方式

    這篇文章主要介紹了redis過期監(jiān)聽機制方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • Redis中AOF與RDB持久化策略深入分析

    Redis中AOF與RDB持久化策略深入分析

    Redis作為一款內(nèi)存數(shù)據(jù)庫,因為是內(nèi)存讀寫,所以性能很強,但內(nèi)存存儲是易失性的,斷電或系統(tǒng)奔潰都會導(dǎo)致數(shù)據(jù)丟失,因此Redis也需要將其數(shù)據(jù)持久化到磁盤上面,當Redis服務(wù)重啟時,會把磁盤上的數(shù)據(jù)再加載進內(nèi)存,Redis提供了兩種持久化機制-RDB快照和AOF日志
    2022-11-11
  • Redis中的延遲雙刪

    Redis中的延遲雙刪

    這篇文章主要介紹了Redis中的延遲雙刪問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • Redis設(shè)置密碼的實現(xiàn)步驟

    Redis設(shè)置密碼的實現(xiàn)步驟

    本文主要介紹了Redis設(shè)置密碼的實現(xiàn)步驟,主要包括兩種方法:臨時密碼和持久密碼,具有一定的參考價值,感興趣的可以了解一下
    2023-08-08
  • Redis操作相關(guān)命令之查看、停止、啟動命令

    Redis操作相關(guān)命令之查看、停止、啟動命令

    這篇文章主要介紹了Redis操作相關(guān)命令之查看、停止、啟動命令,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09

最新評論