Классический ASP и фирменный планшет
Я пытаюсь получить классическую ASP-версию этого приложения для сохранения изображений на моем сервере: https://github.com/szimek/signature_pad
Я пробовал различные комбинации использования вывода Base64, но не имел никакого успеха. Я искал этот сайт и Google, но не смог найти ничего, что имеет для меня смысл.
Если у кого-нибудь есть какие-либо идеи о том, как преобразовать вывод с Signature Pad в изображение на стороне сервера, я был бы очень признателен!
Код JS:
var wrapper = document.getElementById("signature-pad"),
clearButton = wrapper.querySelector("[data-action=clear]"),
savePNGButton = wrapper.querySelector("[data-action=save-png]"),
saveSVGButton = wrapper.querySelector("[data-action=save-svg]"),
canvas = wrapper.querySelector("canvas"),
signaturePad;
// Adjust canvas coordinate space taking into account pixel ratio,
// to make it look crisp on mobile devices.
// This also causes canvas to be cleared.
function resizeCanvas() {
// When zoomed out to less than 100%, for some very strange reason,
// some browsers report devicePixelRatio as less than 1
// and only part of the canvas is cleared then.
var ratio = Math.max(window.devicePixelRatio || 1, 1);
canvas.width = canvas.offsetWidth * ratio;
canvas.height = canvas.offsetHeight * ratio;
canvas.getContext("2d").scale(ratio, ratio);
}
window.onresize = resizeCanvas;
resizeCanvas();
signaturePad = new SignaturePad(canvas);
clearButton.addEventListener("click", function (event) {
signaturePad.clear();
});
savePNGButton.addEventListener("click", function (event) {
if (signaturePad.isEmpty()) {
alert("Please provide signature first.");
} else {
window.open(signaturePad.toDataURL());
}
});
saveSVGButton.addEventListener("click", function (event) {
if (signaturePad.isEmpty()) {
alert("Please provide signature first.");
} else {
window.open(signaturePad.toDataURL('image/svg+xml'));
}
});
Я пытаюсь сделать так, чтобы "savePNGButton" выдавал фактический файл PNG, который я могу сохранить на сервере, используя классический ASP, а не необработанный двоичный файл.
1 ответ
Получив помощь в другом месте, мне удалось решить эту проблему. Во-первых, в нижней части формы была вставлена панель для подписи со следующим кодом:
<div id="signature-pad" class="m-signature-pad">
<div class="m-signature-pad--body">
<canvas id="imageData" name="imageData"></canvas>
</div>
<div class="m-signature-pad--footer">
<div class="description" style="width: 100%; border-top: 1px dotted #999;"></div>
<div class="left">
<button type="button" class="btn btn-warning" data-action="clear">Clear signature</button>
</div>
<div class="right">
<input type="submit" class="btn btn-primary" data-action="save-png" value="Sign and accept terms">
</div>
</div>
</div>
А внутри формы у меня было следующее поле:
<input type="hidden" name="hiddenSignature" id="hiddenSignature" />
Затем на моей странице, отображающей отправку формы, я использовал следующий код (и добавил функцию GetTimeStamp для захвата метки времени, добавляемой к имени файла, чтобы сделать его уникальным):
'Run functions to capture the customer signature
'First function is to grab a timestamp to add to the file name
Function GetTimeStamp ()
Dim dd, mm, yy, hh, nn, ss
Dim datevalue, timevalue, dtsnow, dtsvalue
'Store DateTimeStamp once.
dtsnow = Now()
'Individual date components
dd = Right("00" & Day(dtsnow), 2)
mm = Right("00" & Month(dtsnow), 2)
yy = Year(dtsnow)
hh = Right("00" & Hour(dtsnow), 2)
nn = Right("00" & Minute(dtsnow), 2)
ss = Right("00" & Second(dtsnow), 2)
'Build the date string in the format yyyy-mm-dd
datevalue = yy & "_" & mm & "_" & dd
'Build the time string in the format hh:mm:ss
timevalue = hh & "_" & nn & "_" & ss
'Concatenate both together to build the timestamp yyyy-mm-dd hh:mm:ss
dtsvalue = datevalue & "_" & timevalue
GetTimeStamp = dtsvalue
End Function
'Second, decode the Base64 string
Function SaveToBase64 (base64String)
Dim ImageFileName
Dim Doc
Dim nodeB64
ImageFileName = "signature_" & GetTimeStamp() & ".jpg"
Set Doc = Server.CreateObject("MSXML2.DomDocument")
Set nodeB64 = Doc.CreateElement("b64")
nodeB64.DataType = "bin.base64"
nodeB64.Text = Mid(base64String, InStr(base64String, ",") + 1)
Dim bStream
Set bStream = server.CreateObject("ADODB.stream")
bStream.type = 1
bStream.Open()
bStream.Write( nodeB64.NodeTypedValue )
bStream.SaveToFile Server.Mappath("/uploads/signatures/" & ImageFileName), 2
bStream.close()
Set bStream = nothing
End Function
SaveToBase64(CStr(Request.Form("hiddenSignature")))
Затем он сохраняет версию файла изображения в формате JPG по пути /uploads/ подписи / на сервере.
Файл app.js, загруженный из панели подписи, был изменен следующим образом:
var wrapper = document.getElementById("signature-pad"),
clearButton = wrapper.querySelector("[data-action=clear]"),
savePNGButton = wrapper.querySelector("[data-action=save-png]"),
saveSVGButton = wrapper.querySelector("[data-action=save-svg]"),
canvas = wrapper.querySelector("canvas"),
signaturePad;
// Adjust canvas coordinate space taking into account pixel ratio,
// to make it look crisp on mobile devices.
// This also causes canvas to be cleared.
function resizeCanvas() {
// When zoomed out to less than 100%, for some very strange reason,
// some browsers report devicePixelRatio as less than 1
// and only part of the canvas is cleared then.
var ratio = Math.max(window.devicePixelRatio || 1, 1);
canvas.width = canvas.offsetWidth * ratio;
canvas.height = canvas.offsetHeight * ratio;
canvas.getContext("2d").scale(ratio, ratio);
}
window.onresize = resizeCanvas;
resizeCanvas();
signaturePad = new SignaturePad(canvas, {
backgroundColor: 'rgb(255, 255, 255)'
});
clearButton.addEventListener("click", function (event) {
signaturePad.clear();
});
savePNGButton.addEventListener("click", function (event) {
if (signaturePad.isEmpty()) {
alert("Please provide signature first.");
} else {
$("#hiddenSignature").val(signaturePad.toDataURL("image/jpeg").replace("data:image/jpeg;base64,", ""));
}
});
Я надеюсь, что это поможет кому-то еще, так как это убило меня (и мои навыки начинающего программиста), заставив его работать!