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

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

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

功能需求:

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

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

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

四、從redis數(shù)據(jù)庫(kù)中獲取數(shù)據(jù),轉(zhuǎn)換成音頻流輸出到瀏覽器播放、實(shí)現(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ù)庫(kù)索引(默認(rèn)為0)
 port: 6379 # Redis服務(wù)器連接端口
 password: # Redis服務(wù)器連接密碼(默認(rèn)為空)
 jedis:
 pool:
 max-active: 8 # 連接池最大連接數(shù)(使用負(fù)值表示沒(méi)有限制)
 max-wait: -1ms # 連接池最大阻塞等待時(shí)間(使用負(fù)值表示沒(méi)有限制)
 max-idle: 8 # 連接池中的最大空閑連接
 min-idle: 0 # 連接池中的最小空閑連接
 timeout: 3000ms # 連接超時(shí)時(shí)間(毫秒)

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

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

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

 @Resource
 private RedisTemplate<String,Object> redisTemplate;

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

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

/**
 * 獲取文件將文件轉(zhuǎn)換成byte[]數(shù)組,進(jìn)行分包存儲(chǔ)到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; //每個(gè)字節(jié)包大小
 int viceNumber = (int) Math.ceil(buffer.length /(double) viceLength);//存多少個(gè)包
 int from, to;
 List listrk = new ArrayList();
 for (int i=0;i<viceNumber;i++){ //將完整音頻buffer[]進(jìn)行循環(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列表形式進(jìn)行存儲(chǔ)
 return "redis入庫(kù)成功!";
 }

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

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

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

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

/**
 * 從redis中分包取值進(jìn)行byte[]數(shù)組合并解析音頻
 */
 @RequestMapping("/getkeyAudio")
 public Object getKey(HttpServletResponse response) throws Exception{
 OutputStream os = response.getOutputStream();
 List list =redisTemplate.opsForList().range("Audio", 0, -1); //通過(guò)key獲取指定區(qū)間的值,List方式存儲(chǔ)用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ù)組起始位置, 目標(biāo)數(shù)組, 目標(biāo)數(shù)組起始位置, 復(fù)制長(zhǎng)度);
  System.arraycopy(item, 0, totalByte, begin, item.length);
  begin += item.length;
 }
 os.write(totalByte);//通過(guò)OutputStream對(duì)象輸出合并后的數(shù)組

 return ""; //OutputStream對(duì)象輸出流,直接返回為空,瀏覽器自動(dòng)會(huì)為我們解析音頻流
 }

第一種解析方法:

瀏覽器發(fā)起請(qǐng)求得到音頻二進(jìn)制流,瀏覽器解析自動(dòng)生成一個(gè)播放器播放該音頻及附加下載功能。

第二種解析方法:

在HTML頁(yè)面中定義Audio標(biāo)簽,創(chuàng)建XMLHttpRequest對(duì)象發(fā)起請(qǐng)求,通過(guò)Audio標(biāo)簽進(jìn)行解析。

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

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

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

總結(jié):

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

相關(guān)文章

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

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

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

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

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

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

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

    redis?zset實(shí)現(xiàn)滑動(dòng)窗口限流的代碼

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

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

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

    redis過(guò)期監(jiān)聽(tīng)機(jī)制方式

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

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

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

    Redis中的延遲雙刪

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

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

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

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

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

最新評(píng)論