使用Google Script散列并取消哈希键(Hash and un-hash a key with Google Script)
我需要散列一个键,并且我发现这个方法由
Google Script
提供: https : //developers.google.com/apps-script/reference/utilities/utilities#computeHmacSha256Signature%28String,String%29但是,我怎样才能用这种方法解密密钥?
这是我试图做的事情:
var my_key = "g1w9625bf43bfd91s6c2095c1w160699a59m72t" var hash = Utilities.computeHmacSha256Signature("this", my_key); var un_hash = Utilities.base64Decode(hash);
散列函数有效,但un_hash返回我
Could not decode string
。我感谢任何帮助。
I need to hash a key and I found this method provided by
Google Script
: https://developers.google.com/apps-script/reference/utilities/utilities#computeHmacSha256Signature%28String,String%29But how can I un-hash the key computed with that method?
Here is what I've tried to do:
var my_key = "g1w9625bf43bfd91s6c2095c1w160699a59m72t" var hash = Utilities.computeHmacSha256Signature("this", my_key); var un_hash = Utilities.base64Decode(hash);
The hash function works, but un_hash returns me
Could not decode string
.I appreciate any help.
原文:https://stackoverflow.com/questions/39465329
最满意答案
如果您试图将窗口绘制到内存DC中,请考虑向其发送WM_PRINT消息。 假设你的窗口过程在正常情况下没有做任何特别奇怪的事情,它应该将所有东西都渲染到DC中。 动画可以从那里拍摄。
If you're trying to draw the window into a memory DC, consider sending it the WM_PRINT message. Assuming your window procedure doesn't do anything especially strange in the normal case, it should render everything into your DC. The animation can be taken from there.
相关问答
更多-
TCP/IP模型是一个________。[2023-10-02]
a -
下列中不属于面向对象的编程语言的是?[2022-05-30]
a -
什么是图形上下文?(What exactly is a Graphic Context?)[2023-02-12]
X11 GC不包含内存缓冲区,Drawable和GC都被传递到所有的绘图操作中,并且GC可以与所有“喜欢”Drawables一起使用(可在相同的屏幕上以相同的位深度绘制)。 但是现在通常在客户端使用开罗这样的库进行X11绘图,所以“真实”的答案取决于该库。 在开罗的情况下,开罗背景确实包括了目前的目标表面,尽管你可以改变目标表面。 OpenGL也有一个“当前目标”的概念,尽管你也可以改变当前的目标。 如果你想概括一下,我会说在概念上,一个上下文与缓冲区是分开的,尽管为了节省输入,人们可能有一个当前的缓冲区, ... -
您可以创建多个上下文和“共享列表”,请参阅文档 : 使用glfwCreateWindow创建窗口及其OpenGL或OpenGL ES上下文时,可以指定另一个窗口,其新上下文应与其共享其对象(纹理,顶点和元素缓冲区等)。 GLFWwindow* second_window = glfwCreateWindow(640, 480, "Second Window", NULL, first_window); 这样可以避免为每个窗口复制所有资源,如纹理和缓冲区。 你断言OpenGL不是多线程的。 多个线程可以同时使 ...
-
从像素缓冲区到设备上下文的最快方法(Fastest method for blitting from a pixel buffer into a device context)[2023-06-27]
有一个API方法CreateDIBSection来创建应用程序可以直接写入的DIB。 这允许不断更新位图(memcopy或直接写入它)。 有关详细信息,请参阅MSDN文章。 必须同步对位图的访问。 通过调用GdiFlush函数来完成此操作。 There is an API method CreateDIBSection to create a DIB that applications can write to directly. This allows to continuously updating t ... -
根据您的显示,您似乎使用了错误的DC。 您似乎使用DC作为对话框(即CCLientDC)而不是实际的CImage。 你应该从中构建DC CImage :: GetDC() 。 该DC将具有当前选择的位图。 From what you've shown, it appears you are using the wrong DC. You seem to be using the DC for the dialog (ie. CCLientDC) and not the actual CImage. You ...
-
我将屏幕保护程序构建为一个瘦的包装函数,它只获取一个设备上下文,然后调用另一个函数来绘制到DC: void On_WmPaint() { HDC dc = BeginPaint(); // ... do_draw(dc); EndPaint(); } void do_draw(HDC dc) { // ... } 然后,当您想为视频创建一个帧时,可以使用CreateCompatibleDC(一种可能性)创建与您的屏幕兼容的DC。 然后使用CreateCompati ...
-
如果您试图将窗口绘制到内存DC中,请考虑向其发送WM_PRINT消息。 假设你的窗口过程在正常情况下没有做任何特别奇怪的事情,它应该将所有东西都渲染到DC中。 动画可以从那里拍摄。 If you're trying to draw the window into a memory DC, consider sending it the WM_PRINT message. Assuming your window procedure doesn't do anything especially strange ...
-
CreateCompatibleDC(NULL)将创建一个与屏幕兼容的设备上下文 - 听起来它在这种情况下是理想的。 CreateCompatibleDC(NULL) will create you a device context that is compatible with the screen - which sounds like it would be ideal in the situation.
-
最简单的方法是在使用win32 API调用PrintDlg或在使用MFC时调用CPrintDialog::GetPrinterDC之后,使用PRINTDLG.hDevMode和PRINTDLG.hDevNames构造设备上下文。 如果使用MFC: CPrintDialog dlgPrint(FALSE, PD_USEDEVMODECOPIES); HDC hPrinterDC = dlgPrint.GetPrinterDC(); 或win32 API: HDC hPrinterDC = NULL; PRI ...