⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 testmd5.c

📁 Apache官方在今天放出产品系列2.2的最新版本2.2.11的源码包 最流行的HTTP服务器软件之一
💻 C
字号:
/* Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements.  See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License.  You may obtain a copy of the License at * *     http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */#include <assert.h>#include <stdio.h>#include <stdlib.h>#include "apr_md5.h"#include "apr_xlate.h"#include "apr_general.h"#include "abts.h"#include "testutil.h"static struct {    const char *string;    const char *digest;} md5sums[] = {    {"Jeff was here!",     "\xa5\x25\x8a\x89\x11\xb2\x9d\x1f\x81\x75\x96\x3b\x60\x94\x49\xc0"},    {"01234567890aBcDeFASDFGHJKLPOIUYTR"     "POIUYTREWQZXCVBN  LLLLLLLLLLLLLLL",     "\xd4\x1a\x06\x2c\xc5\xfd\x6f\x24\x67\x68\x56\x7c\x40\x8a\xd5\x69"},    {"111111118888888888888888*******%%%%%%%%%%#####"     "142134u8097289720432098409289nkjlfkjlmn,m..   ",     "\xb6\xea\x5b\xe8\xca\x45\x8a\x33\xf0\xf1\x84\x6f\xf9\x65\xa8\xe1"},    {"01234567890aBcDeFASDFGHJKLPOIUYTR"     "POIUYTREWQZXCVBN  LLLLLLLLLLLLLLL"     "01234567890aBcDeFASDFGHJKLPOIUYTR"     "POIUYTREWQZXCVBN  LLLLLLLLLLLLLLL"     "1",     "\xd1\xa1\xc0\x97\x8a\x60\xbb\xfb\x2a\x25\x46\x9d\xa5\xae\xd0\xb0"}};static int num_sums = sizeof(md5sums) / sizeof(md5sums[0]);static int count;static void test_md5sum(abts_case *tc, void *data){        apr_md5_ctx_t context;        unsigned char digest[APR_MD5_DIGESTSIZE];        const void *string = md5sums[count].string;        const void *sum = md5sums[count].digest;        unsigned int len = strlen(string);        ABTS_ASSERT(tc, "apr_md5_init", (apr_md5_init(&context) == 0));        ABTS_ASSERT(tc, "apr_md5_update",                     (apr_md5_update(&context, string, len) == 0));        ABTS_ASSERT(tc, "apr_md5_final", (apr_md5_final(digest, &context)                                          == 0));        ABTS_ASSERT(tc, "check for correct md5 digest",                    (memcmp(digest, sum, APR_MD5_DIGESTSIZE) == 0));}abts_suite *testmd5(abts_suite *suite){        suite = ADD_SUITE(suite);                for (count=0; count < num_sums; count++) {            abts_run_test(suite, test_md5sum, NULL);        }        return suite;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -