1

在 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
4

1 回答 1

1

好的,所以在一行中执行此操作的方法是使用 base64,如下所示:

(echo -e -n use "AVL \\ngo\\nexec spAVL_SetAlertIVR 1, '";(base64 myFile.wav|tr -d '\n');echo -n -e "'\\ngo") | tsql -H 192.168.1.111 -p 1433 -U sa -P x

注意“()”和“|”的使用 以及使用“tr -d”删除base64命令留下的CR的技巧。

希望这对其他人有帮助

于 2011-10-27T12:06:53.963 回答