在 Asterisk 应用程序(拨号计划)中,我需要在 MSSQL 数据库中插入一个声音文件。我正在使用 freeTDS 与数据库进行通信。
示例表称为“testblob”
(id int identity, name varchar(50), audiofile varbinary(MAX))
我正在尝试使用此代码:
exten => s,n,Set(arch=${FILE(/var/lib/asterisk/sounds/custom/myFile.wav)})
exten => s,n,Verbose(${arch})
exten => s,n,Set(RESULT=${SHELL(echo -e use "AVL \\ngo\\ninsert into testblob (name, audiofile) values ('mar',${arch})\\ngo"|tsql -H x.x.x.x -p 1433 -U sa -P x)})
但是由于 de ${arch} 变量中的“特殊字符”,因此肯定无法正常工作。我知道 $arch 里面是文件信息,但我想我需要以二进制或 64encode 或类似的方式读取它。
问题是:有没有办法直接从外壳插入这个 myFile.wav ?就像是:
echo -e use "AVL \\ngo\\ninsert into testblob (name, audiofile) values ('mar',####MAGIC GOES HERE TO READ MYFILE.WAV###)\\ngo"|tsql -H x.x.x.x -p 1433 -U sa -P x