防止已经转码的中文地址二次转码

防止已经转码的中文地址二次转码


在公司项目中,视频播放的时候,url可能已经utf-8转码了,也可能未转码而包含中文,对url中的中文进行转码时,如果url中的中文已经是utf-8转码了,那么会二次转码,在项目需求中url就无效。

对url中的中文进行转码(如果已知url中的中文没有进行utf-8转码)

url = [url stringByAddingPercentEncodingWithAllowedCharacters:[NSCharacterSet URLQueryAllowedCharacterSet]];

如果知道url中的中文既可能已经转码,也可能没有转码,那么使用如下的方法,当不管url中的中文是否已经utf-8转码了,都可以解决将中文字符转为utf-8的问题,且不是二次转码

NSLog(@"原url:%@", url);
NSString *encodedString = (NSString *)
CFBridgingRelease(CFURLCreateStringByAddingPercentEscapes(kCFAllocatorDefault, (CFStringRef)url,  (CFStringRef)@"!$&'()*+,-./:;=?@_~%#[]",  NULL, kCFStringEncodingUTF8));
NSLog(@"转码url:%@",  encodedString);
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现 FFmpeg + Nginx 实时码并播放 FLV 视频,可以按照以下步骤进行配置: 1. 安装 FFmpeg 和 Nginx,并启动 Nginx 服务器。 2. 在 Nginx 配置文件中添加以下内容: ``` rtmp { server { listen 1935; chunk_size 4096; application live { live on; record off; allow publish all; allow play all; exec ffmpeg -i rtmp://localhost:1935/live/$name -c:v libx264 -preset ultrafast -c:a aac -f flv rtmp://localhost:1935/hls/$name; } application hls { live on; hls on; hls_path /var/www/html/hls; hls_fragment 5s; hls_playlist_length 30s; allow play all; } } } ``` 3. 在上述配置中,`rtmp` 块用于定义 RTMP 流协议的服务器,`application live` 块用于定义实时直播的应用,`application hls` 块用于定义 HLS(HTTP Live Streaming)应用。 4. 在`application live` 块中,`live on` 参数用于启用实时直播,`exec` 指令调用 FFmpeg 进行实时码,将 RTMP 流换为 FLV 格式并推送到`application hls`应用的 HLS 流服务器上进行播放。 5. 在`application hls` 块中,`hls on` 参数用于启用 HLS 流协议,`hls_path` 参数用于指定存放 HLS 流的目录,`hls_fragment` 参数用于指定每个 TS 片段的时长,`hls_playlist_length` 参数用于指定 HLS 流的播放列表时长。 6. 配置完成后,可以使用 RTMP 推流软件向 Nginx 服务器推送实时直播流,例如使用 OBS Studio 软件进行推流。 7. 播放实时直播流时,可以使用以下 URL 地址: ``` http://<server-ip>/hls/<stream-name>.m3u8 ``` 其中,`<server-ip>` 是 Nginx 服务器的公网 IP 地址,`<stream-name>` 是实时直播流的名称。 以上就是使用 FFmpeg + Nginx 实现实时码并播放 FLV 视频的步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值