缺少类型说明符 - 假设为int

时间:2015-03-02 14:32:47

标签: c dll code-injection inject

我一直试图在这些代码堆栈上解决这个问题。我试图在我的可执行文件上阻止注入等。

我这样称呼我的功能:

#include "Protect.h"

EL_DenyProcessAccess();

错误C4430:缺少类型说明符 - 假设为int。注意:C ++不支持default-int
错误C2146:语法错误:缺少';'在标识符' EL_DenyProcessAccess'

之前
#pragma once

#include "AccCtrl.h"
#include "Aclapi.h"

BOOL EL_FORCEINLINE EL_DenyProcessAccess( void )
{
    BYTE    abyBuffer[0x200];
    PACL    pACL;
    SID_IDENTIFIER_AUTHORITY stIdentifierAuthority = SECURITY_WORLD_SID_AUTHORITY;
    PSID pSid = NULL;
    BOOL bRet = FALSE;
    DWORD dwSize = 0;
    HANDLE hToken = NULL;
    HANDLE hProcess = ::GetCurrentProcess();
    PTOKEN_USER pUserInfo = NULL;

    if( ::AllocateAndInitializeSid( &stIdentifierAuthority, 1, SECURITY_WORLD_RID, 0, 0, 0, 0, 0, 0, 0, &pSid ) == FALSE )
        goto Cleanup;
    if( ::OpenProcessToken( hProcess, TOKEN_QUERY, &hToken ) == FALSE )
        goto Cleanup;
    ::GetTokenInformation( hToken, TokenUser, NULL, NULL, &dwSize );
    if( dwSize > 1024 )
        goto Cleanup;
    pUserInfo = (PTOKEN_USER) ::GlobalAlloc( GPTR, dwSize );
    if( pUserInfo == NULL )
        goto Cleanup;
    if( ::GetTokenInformation( hToken, TokenUser, pUserInfo, dwSize, &dwSize ) == FALSE )
        goto Cleanup;
    pACL = (PACL) &abyBuffer;
    if( ::InitializeAcl( pACL, 0x200, ACL_REVISION ) == FALSE )
        goto Cleanup;
    // Deny except PROCESS_TERMINATE and PROCESS_SET_SESSIONID
    if( ::AddAccessDeniedAce( pACL, ACL_REVISION, PROCESS_CREATE_PROCESS | PROCESS_DUP_HANDLE | PROCESS_VM_WRITE | PROCESS_VM_READ | PROCESS_VM_OPERATION | PROCESS_CREATE_THREAD, pSid ) == FALSE )
        goto Cleanup;
    // Allow SYNCHRONIZE, PROCESS_QUERY_INFORMATION, PROCESS_SET_INFORMATION, PROCESS_SET_QUOTA and PROCESS_TERMINATE
    if( ::AddAccessAllowedAce( pACL, ACL_REVISION, SYNCHRONIZE | PROCESS_QUERY_INFORMATION | PROCESS_SET_INFORMATION | PROCESS_SET_QUOTA | PROCESS_TERMINATE, pUserInfo->User.Sid ) == FALSE )
        goto Cleanup;
    if( ::SetSecurityInfo( hProcess, SE_KERNEL_OBJECT, PROTECTED_DACL_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION, 0, 0, pACL, 0 ) != ERROR_SUCCESS )
        goto Cleanup;
    bRet = TRUE;
Cleanup:
    if ( hToken )
        ::CloseHandle( hToken );
    if ( pSid )
        ::FreeSid( pSid );
    return bRet;
}

我的代码无法看到任何错误?

1 个答案:

答案 0 :(得分:0)

编译器显然将代码视为C ++。这是您收到错误的原因。

问题是未定义BOOL和EL_FORCEINLINE。 所以预处理器翻译

BOOL EL_FORCEINLINE EL_DenyProcessAccess( void )

进入

EL_DenyProcessAccess( void )

您应该确保定义了BOOL。

在C中,如果未指定返回类型,则假定类型为int。它可能是作者所希望的行为,但它容易出错。