首先查了一些资料:

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\n`nonce`.`Context`, \n`nonce`.`Code`, \n`nonce`.`Timestamp`\nFROM `nonce` AS' at line 1"}

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

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

DotNetOpenAuth使用笔记的更多相关文章

  1. git-简单流程(学习笔记)

    这是阅读廖雪峰的官方网站的笔记,用于自己以后回看 1.进入项目文件夹 初始化一个Git仓库,使用git init命令. 添加文件到Git仓库,分两步: 第一步,使用命令git add <file ...

  2. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  3. SQL Server技术内幕笔记合集

    SQL Server技术内幕笔记合集 发这一篇文章主要是方便大家找到我的笔记入口,方便大家o(∩_∩)o Microsoft SQL Server 6.5 技术内幕 笔记http://www.cnbl ...

  4. PHP-自定义模板-学习笔记

    1.  开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2.  整体架构图 ...

  5. PHP-会员登录与注册例子解析-学习笔记

    1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...

  6. NET Core-学习笔记(三)

    这里将要和大家分享的是学习总结第三篇:首先感慨一下这周跟随netcore官网学习是遇到的一些问题: a.官网的英文版教程使用的部分nuget包和我当时安装的最新包版本不一致,所以没法按照教材上给出的列 ...

  7. springMVC学习笔记--知识点总结1

    以下是学习springmvc框架时的笔记整理: 结果跳转方式 1.设置ModelAndView,根据view的名称,和视图渲染器跳转到指定的页面. 比如jsp的视图渲染器是如下配置的: <!-- ...

  8. 读书笔记汇总 - SQL必知必会(第4版)

    本系列记录并分享学习SQL的过程,主要内容为SQL的基础概念及练习过程. 书目信息 中文名:<SQL必知必会(第4版)> 英文名:<Sams Teach Yourself SQL i ...

  9. 2014年暑假c#学习笔记目录

    2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...

随机推荐

  1. 20169212《Linux内核原理与分析》第六周作业

    视频学习 一.用户态.内核态和中断 内核态:处于高的执行级别下,代码可以执行特权指令,访问任意的物理地址,这时的CPU就对应内核态 用户态:处于低的执行级别下,代码只能在级别允许的特定范围内活动.在日 ...

  2. web工程关于500错误

    昨天一直被一个诡异问题困扰,解决了之后开心得的我连玩了一下午,哈哈哈哈哈哈哈哈-- 具体问题是这样的额,本地跑的贼正常,一发到测试服务器就报500错误,具体错误信息是.  HTTP Status 50 ...

  3. HTML5的入门与深入理解

    HTML5是对HTML的第5次重大的修改,虽然HTML5 标准还在制定中,但不能阻碍其势不可挡的脚步,不用HTML5你就OUT了.HTML5与我们常用的HTML4有什么区别呢? 首先要说的是不是所有的 ...

  4. html slelect 标签默认值

    <select name="channelCode" id="channelCode" class="all_input" style ...

  5. Centos 6.5 把自带python 2.6.6, 升级到 2.7

    http://blog.csdn.net/jcjc918/article/details/11022345

  6. navicat快捷键

    ctrl+R.N 运行窗口sql ctrl+shift+r 运行选择sql ctr+q 打开窗口 ctrl+/   |ctrl+shift+/ 注释   | 解除 ctrl+L 删除一行的内容 ctr ...

  7. URL优化之IIS7如何开启伪静态

    iis7跟IIS6开启伪静态重写的方式不一样,iis6是在网站属性里面的ISAPI筛选器里面添加,但是iis7添加伪静态重写,需要下载一个url重写插件. II7/7.5用的是web.config配置 ...

  8. 将已有项目提交到github/从github上pull到本地

    去自己的工作分支$ git checkout work 工作.... 提交工作分支的修改$ git commit -a 回到主分支$ git checkout master 获取远程最新的修改,此时不 ...

  9. css3选择器详解

    css中除了早先最早的,ID选择器,class选择器一些以外在css3中新加入了新的选择器,新选择器的使用大大的方便了我们的编程,下面我就说一些css3的选择器的使用方法, p       选择了所有 ...

  10. 用markdown学习写出总结

    # PS### 快捷键:CTRL+N(新建)CTRL+1. **切片**- 套索,磁性套索,椭圆,矩形选框.2. **印章** 仿制图章工具,图案图章工具3. 钢笔4. 油漆桶5. 吸管工具, *** ...