zoukankan      html  css  js  c++  java
  • DotNetOpenAuth使用笔记

    首先查了一些资料:

    DotNetOpenAuth源码 https://github.com/DotNetOpenAuth/DotNetOpenAuth

    永远的阿哲分享的经验和Demo http://www.cnblogs.com/ljzforever/archive/2013/04/01/2985456.html

    等到自己用起来还是出了不少问题,现总结如下:

    环境:VisualStudio 2013,Mysql Server 5.5,EntityFramework 6

    问题一:MySQL不会建外键,Engin必须是InnoDB才支持外键

    方法一、修改my.ini的默认,在[mysqld]下加上
    default-storage-engine=INNODB
    方法二、用sql语句修改已经建成表的引擎:
    alter table tableName type=InnoDB

    方法三、MySQL Workbench里修改,我的Wokbench是V6.1:

       

    问题二:Unable to add data entity model

    弹窗窗口询问”你要使用实体框架的哪个版本“

    这篇文章有讲解,使用EntityFramework6连接MySql数据库(db first方式) http://www.cnblogs.com/24la/p/ef6-mysql.html

    问题三:不算问题,顺便看了一下ModelFirst,添加EntityDataModel的时候选择EmptyModel,然后在里面添加Entity,之后修改一下属性就可以生成SQL脚本了

    问题三:报错安全透明方法"A"常识访问安全关键类型"B"失败。程序集”C"标记为AllowPartiallyTrustedCallersAttribute并且是要用2级安全透明模型……

      下载源码后,运行一下,然后把dll拷出来用,感觉应该是这个原因造成的,然后install-package DotNetOpenAuth这样引用就没报错了。

    问题四:运行的时候报错Missing decryption key for bucket ”https://localhost/dnoa/oauth_authorization_code" handle "Mfvy",谷歌了一下,说是”https://localhost/dnoa/oauth_authorization_code"是固定的内容,然后看看bucket和handle

    在数据表symmetriccryptokey中,想应该是表设计错了

      源码中没有数据库设计,参不透源码,那么看园友的Demo,有数据库,是.db3后缀,需要安装ShartPlus SQLit,中Secret类型和长度设错了,设成binnary 32位,不再报这个错了。

    问题五:报错An exception of type 'System.Data.Entity.Validation.DbEntityValidationException' occurred in EntityFramework.dll but was not handled in user code

    Demo数据库对比,发现是Nonce表,我设置成联合主键,因为从Demo的EFModel上看是联合主键,而Demo的数据库表没有主键,明白了,应该是EF给没有主键的表自动生成联合主键,所以去掉数据库的主键,update model from database,嗯,EFModel上依然显示联合主键,证明猜测没错!

    但是又报错了 

    An error occurred while updating the entries. See the inner exception for details.
    {"You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '(SELECT `nonce`.`Context`, `nonce`.`Code`, `nonce`.`Timestamp` FROM `nonce` AS' at line 1"}

    谷歌一下Unable to add new entity with context.saveChanges() method.原来MySQL的原因,EF连接MySQL,数据库表不能没有主键,添加了一个自动增长的ID列为主键,保存成功了。

     

    总结一下,折腾了这么久,基本都是数据库的问题!记录一下,也希望对别人有用。

  • 相关阅读:
    list和set的区别
    day13
    11期
    接口是否可继承接口? 抽象类是否可实现(implements)接口? 抽象类是否可继承具体类(concrete class)? 抽象类中是否可以有静态的main方法?
    Object类?
    swith的用法和注意事项?
    Ioc和DI的区别?
    多态的好处?
    抽象和接口的区别?
    内部类,匿名内部类?
  • 原文地址:https://www.cnblogs.com/LLLLoveLLLLife/p/3897796.html
Copyright © 2011-2022 走看看